## Old Company Name in Catalogs and Other Documents

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

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

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

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

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



## Notice

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



# MOS INTEGRATED CIRCUIT $\mu$ PD17016, 17017

# 4-BIT SINGLE-CHIP MICROCONTROLLERS WITH DIGITAL TUNING SYSTEM HARDWARE

The  $\mu$ PD17016 and 17017 are 4-bit single-chip CMOS microcontrollers equipped with hardware for digital tuning systems.

The CPU employs the 17K architecture and can directly manipulate the data memory, execute various operations, and control the peripheral hardware with a single instruction. All the instructions are one-word 16-bit instructions.

As the peripheral hardware, a prescaler that can operate at up to 150 MHz, PLL frequency synthesizer, and frequency counter for digital tuning systems, as well as many I/O ports, an LCD controller/driver, A/D converter, and D/A converter (PWM output) are provided.

Therefore, a high-performance, state-of-the-art digital tuning system can be organized with a single chip. In addition to the  $\mu$ PD17016 and 17017, a one-time PROM model for program evaluation, the  $\mu$ PD17P005, is also available.

#### **FEATURES**

- 17K architecture: general-purpose register method
- Program memory (ROM)

8 KB (3836  $\times$  16 bits) :  $\mu$ PD17016 16 KB (7932  $\times$  16 bits) :  $\mu$ PD17017

· General-purpose data memory (RAM)

 $320 \times 4$  bits:  $\mu$ PD17016  $432 \times 4$  bits:  $\mu$ PD17017

- Instruction execution time
   4.44 μs (with 4.5-MHz crystal resonator)
- · Decimal operation
- · Table reference
- Hardware for PLL frequency synthesizer
   Dual modulus prescaler (150 MHz max.), programmable divider, charge pump

- A wealth of peripheral hardware
   General-purpose I/O ports, LCD controller/driver, serial interface, A/D converter, D/A converter (PWM output), BEEP output, frequency counter
- Interrupt External: 1 Internal: 1
- Power-ON reset, reset by CE pin, and power failure detection circuit
- Power-saving CMOS
- Supply voltage: VDD = 5 V±10%

Unless otherwise specified, the µPD17017 is explained as the representative model in this document.

The information in this document is subject to change without notice.



## **ORDERING INFORMATION**

| Part Number             | Package                                |  |  |  |
|-------------------------|----------------------------------------|--|--|--|
| $\mu$ PD17016GF-×××-3B9 | 80-pin plastic QFP (14 $\times$ 20 mm) |  |  |  |
| $\mu$ PD17017GF-××-3B9  | 80-pin plastic QFP (14 $	imes$ 20 mm)  |  |  |  |

**Remark** ××× indicates a ROM code number.

## FUNCTIONAL OUTLINE OF $\mu$ PD17016 AND 17017

| Item                              | Function                                                                                                                                                                                                                                              |  |  |  |  |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Program memory (ROM)              | • 8 KB (3836 $\times$ 16 bits) : $\mu$ PD17016<br>• 16 KB (7932 $\times$ 16 bits) : $\mu$ PD17017<br>All internal ROM areas can be referenced as a table.                                                                                             |  |  |  |  |
| General-purpose data memory (RAM) | <ul> <li>320 × 4 bits : μPD17016</li> <li>432 × 4 bits : μPD17017</li> <li>General register: 16 × 4 bits</li> </ul>                                                                                                                                   |  |  |  |  |
| Instruction execution time        | • 4.44 μs (with 4.5-MHz crystal resonator)                                                                                                                                                                                                            |  |  |  |  |
| Stack level                       | 7 levels (stack can be manipulated)                                                                                                                                                                                                                   |  |  |  |  |
| General-purpose port              | <ul> <li>I/O port : 16 pins</li> <li>Input port : 8 pins</li> <li>Output port : 9 pins (+8: LCD segment pin)</li> </ul>                                                                                                                               |  |  |  |  |
| BEEP output                       | 1 pin     Selectable frequency (200 Hz, 1 kHz, 3 kHz)                                                                                                                                                                                                 |  |  |  |  |
| LCD controller/driver             | 30 segments, 2 commons     1/2 duty, 1/2 bias, frame frequency: 125 MHz, drive voltage: V <sub>DD</sub> , segment pins multiplexed with key source pins: 16     8 pins can be used as output port pins (4 pins can be set in output mode at one time) |  |  |  |  |
| Serial interface                  | 1 channel     3-wire (serial I/O)                                                                                                                                                                                                                     |  |  |  |  |
| D/A converter                     | 8 bits × 2 channels (PWM output, output voltage: 16 V MAX.)                                                                                                                                                                                           |  |  |  |  |
| A/D converter                     | 6 bits × 6 channels (successive approximation by software)                                                                                                                                                                                            |  |  |  |  |
| Interrupt                         | 2 sources (maskable interrupt)     External : 1 source (INT <sub>0</sub> pin)     Internal : 1 source (timer)                                                                                                                                         |  |  |  |  |
| Timer                             | • 2 channels Timer carry (1, 5, 100, 250 ms) Timer interrupt (1, 5, 100, 250 ms)                                                                                                                                                                      |  |  |  |  |
| Reset                             | <ul> <li>Power-ON reset (on power application)</li> <li>Reset by CE pin (CE pin low level → high level)</li> <li>Power failure detection function</li> </ul>                                                                                          |  |  |  |  |



| Item                      |                     | Function                                                                                                                                  |  |  |  |
|---------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| PLL frequency synthesizer | Division mode       | Two types     Direct division mode (VCOL pin : 30 MHz MAX.)     Pulse swallow mode (VCOL pin : 40 MHz MAX.)     (VCOH pin : 150 MHz MAX.) |  |  |  |
|                           | Reference frequency | • 12 programmable frequencies<br>1, 1.25, 2.5, 3, 5, 6.25, 9, 10, 12.5, 25, 50, 100 kHz                                                   |  |  |  |
|                           | Charge pump         | Two independent error out outputs                                                                                                         |  |  |  |
|                           | Phase comparator    | Unlock detection by program                                                                                                               |  |  |  |
| Frequency counter         |                     | Frequency measurement     P1D <sub>3</sub> /FMIFC pin : 5 to 15 MHz     P1D <sub>2</sub> /AMIFC pin : 0.1 to 1 MHz                        |  |  |  |
| Supply voltage            |                     | V <sub>DD</sub> = 5 V±10%                                                                                                                 |  |  |  |
| Package                   |                     | 80-pin plastic QFP (14 × 20 mm)                                                                                                           |  |  |  |



## PIN CONFIGURATION (Top View)

80-pin plastic QFP (14  $\times$  20 mm, 0.8 mm pitch)  $\mu$ PD17016GF- $\times\times$ -3B9  $\mu$ PD17017GF- $\times\times$ -3B9



## **PIN NAME**

P0C<sub>0</sub>-P0C<sub>3</sub>

P0D<sub>0</sub>-P0D<sub>3</sub>

: Port 0C

: Port 0D

: A/D converter input P0E<sub>0</sub>-P0E<sub>3</sub> : Port 0E ADC<sub>0</sub>-ADC<sub>5</sub> **AMIFC** : AM intermediate frequency P0F<sub>0</sub>-P0F<sub>3</sub> : Port 0F

counter input P1A<sub>0</sub>-P1A<sub>3</sub>

: Port 1A P1B<sub>0</sub>-P1B<sub>3</sub> **BEEP** : BEEP output : Port 1B CE : Chip enable input P1C<sub>0</sub>-P1C<sub>3</sub> : Port 1C

COM<sub>0</sub>, COM<sub>1</sub> : LCD common signal output P1D<sub>0</sub>-P1D<sub>3</sub> : Port 1D EO<sub>0</sub>, EO<sub>1</sub> : Error out output P2A<sub>0</sub> : Port 2A

**FMIFC** : FM intermediate frequency PWM<sub>0</sub>, PWM<sub>1</sub> : D/A converter output

> counter input SCK : Serial clock I/O SI : Serial data input

**GND** : Ground IC<sub>0</sub>-IC<sub>3</sub> : Internal connection SO : Serial data output

INT<sub>0</sub> : External interrupt input **VCOH** : Local oscillation high input KS<sub>0</sub>-KS<sub>15</sub> : Key source signal output VCOL : Local oscillation low input

LCD<sub>0</sub>-LCD<sub>29</sub> : LCD segment signal output VDD1, VDD2 : Power supply

P0A<sub>0</sub>-P0A<sub>3</sub> : Port 0A XIN, XOUT : Crystal resonator connection : Port 0B P0B<sub>0</sub>-P0B<sub>3</sub>



#### **BLOCK DIAGRAM**



## Contents

| 1. | PIN F | UNCTIONS                                                                     | 12 |
|----|-------|------------------------------------------------------------------------------|----|
|    | 1.1   | Pin Function List                                                            | 12 |
|    | 1.2   | Notes on Using General-Purpose Port                                          | 17 |
|    | 1.3   | Equivalent Circuits of Pins                                                  | 18 |
|    | 1.4   | Processing of Unused Pins                                                    | 22 |
|    | 1.5   | Notes on Using CE and INT0 Pins                                              | 23 |
| 2. | PROC  | SRAM MEMORY (ROM)                                                            | 24 |
|    | 2.1   | Outline of Program Memory                                                    | 24 |
|    | 2.2   | Program Memory                                                               | 25 |
|    | 2.3   | Program Counter                                                              | 26 |
|    | 2.4   | Program Flow                                                                 | 26 |
|    | 2.5   | Notes on Using Program Memory                                                | 28 |
| 3. | ADDF  | RESS STACK (ASK)                                                             | 29 |
|    | 3.1   | Outline of Address Stack                                                     | 29 |
|    | 3.2   | Address Stack Register (ASR)                                                 | 29 |
|    | 3.3   | Stack Pointer (SP)                                                           | 31 |
|    | 3.4   | Operation of Address Stack                                                   | 32 |
|    | 3.5   | Notes on Using Address Stack                                                 | 32 |
| 4. | DATA  | MEMORY (RAM)                                                                 | 33 |
|    | 4.1   | Outline of Data Memory                                                       | 33 |
|    | 4.2   | Configuration and Function of Data Memory                                    | 34 |
|    | 4.3   | Addressing of Data Memory                                                    | 36 |
|    | 4.4   | Notes on Using Data Memory                                                   | 37 |
| 5. | SYST  | EM REGISTER (SYSREG)                                                         | 38 |
|    | 5.1   | Outline of System Register                                                   | 38 |
|    | 5.2   | System Register List                                                         |    |
|    | 5.3   | Address Register (AR)                                                        |    |
|    | 5.4   | Window Register (WR)                                                         |    |
|    | 5.5   | Bank Register (BANK)                                                         |    |
|    | 5.6   | Index Register (IX) and Data Memory Row Address Pointer (MP: Memory Pointer) |    |
|    | 5.7   | General Register Pointer (RP)                                                | 46 |
|    | 5.8   | Program Status Word (PSWORD)                                                 | 48 |
|    | 5.9   | Notes on Using System Register                                               | 49 |
| 6. | GENE  | ERAL REGISTER (GR)                                                           | 50 |
|    | 6.1   | Outline of General Register                                                  |    |
|    | 6.2   | General Register Body                                                        | 50 |
|    | 6.3   | Address Generation of General Register by Each Instruction                   | 51 |
|    | 6.4   | Notes on Using General Register                                              | 52 |

| 7.  | ALU ( | Arithmetic Logic Unit) BLOCK                               | 53  |
|-----|-------|------------------------------------------------------------|-----|
|     | 7.1   | Outline of ALU Block                                       | 53  |
|     | 7.2   | Configuration and Function of Each Block                   | 54  |
|     | 7.3   | ALU Processing Instruction List                            | 54  |
|     | 7.4   | Notes on Using ALU                                         | 58  |
| 8.  | REGIS | STER FILE (RF)                                             | 59  |
|     | 8.1   | Outline of Register File                                   |     |
|     | 8.2   | Configuration and Function of Register File                | 60  |
|     | 8.3   | Control Registers                                          |     |
|     | 8.4   | Notes on Using Register File                               | 66  |
| 9.  | DATA  | BUFFER (DBF)                                               | 67  |
|     | 9.1   | Outline of Data Buffer                                     | 67  |
|     | 9.2   | Data Buffer                                                | 68  |
|     | 9.3   | Peripheral Hardware and Data Buffer List                   |     |
|     | 9.4   | Notes on Using Data Buffer                                 | 72  |
| 10. | INTER | RUPT                                                       | 73  |
|     | 10.1  | Outline of Interrupt Block                                 |     |
|     | 10.2  | Interrupt Control Block                                    |     |
|     | 10.3  | Interrupt Stack Register                                   |     |
|     | 10.4  | Stack pointer, address stack register, and program counter |     |
|     | 10.5  | Interrupt Enable Flip-Flop (INTE)                          | 79  |
|     | 10.6  | Acknowledging Interrupts                                   |     |
|     | 10.7  | Operation After Interrupt Has been Acknowledged            |     |
|     | 10.8  | Restoring from Interrupt Processing Routine                |     |
|     | 10.9  | External (INT <sub>0</sub> Pin) Interrupt                  |     |
|     |       | Internal Interrupt                                         |     |
|     |       | Notes on Using Interrupt                                   |     |
|     |       |                                                            |     |
| 11. |       | R FUNCTION                                                 |     |
|     | 11.1  | Configuration of Timer                                     |     |
|     | 11.2  | Functional Outline of Timer                                |     |
|     | 11.3  | Timer Carry                                                |     |
|     | 11.4  | Timer Interrupt                                            | 105 |
| 12. | STAN  |                                                            | 114 |
|     | 12.1  | Configuration of Standby Block                             |     |
|     | 12.2  | Standby Function                                           |     |
|     | 12.3  | Selecting Device Operation Mode with CE Pin                |     |
|     | 12.4  | Halt Function                                              |     |
|     | 12.5  | Clock Stop Function                                        |     |
|     | 12.6  | Device Operations in Halt and Clock Stop Status            |     |
|     | 12.7  | Current Consumption in Halt Status and Clock Stop Status   | 131 |

| 13. | RESE  | T                                                                 |     |
|-----|-------|-------------------------------------------------------------------|-----|
|     | 13.1  | Configuration of Reset Block                                      | 136 |
|     | 13.2  | Reset Function                                                    | 137 |
|     | 13.3  | CE Reset                                                          | 138 |
|     | 13.4  | Power-ON Reset                                                    |     |
|     | 13.5  | Relation between CE Reset and Power-ON Reset                      |     |
|     | 13.6  | Power Failure Detection                                           |     |
|     | 13.0  | 1 OWCI T dilute Detection                                         | 130 |
| 1/  | DII E | REQUENCY SYNTHESIZER                                              | 158 |
| 17. | 14.1  | Configuration of PLL Frequency Synthesizer                        |     |
|     | 14.2  | Functional Outline of PLL Frequency Synthesizer                   |     |
|     | 14.3  | Input Select Block and Programmable Divider                       |     |
|     | 14.3  | Reference Frequency Generator                                     |     |
|     | 14.4  | Phase Comparator (φ-DET), Charge Pump, and Unlock Detection Block |     |
|     | 14.5  |                                                                   |     |
|     |       | PLL Disabled Status                                               |     |
|     | 14.7  | Using PLL Frequency Synthesizer                                   |     |
|     | 14.8  | Status on Reset                                                   | 1/5 |
| 45  | OFNE  | TRAL DUDDOCE DODT                                                 | 470 |
| 15. |       | RAL-PURPOSE PORT                                                  |     |
|     | 15.1  | Configuration and Classification of General-Purpose Ports         |     |
|     | 15.2  | Functional Outline of General-Purpose Ports                       |     |
|     | 15.3  | General-Purpose I/O Ports (P0A, P0B, P0C, and P1A)                |     |
|     | 15.4  | General-Purpose Input Ports (P0D and P1D)                         |     |
|     | 15.5  | General-Purpose Output Ports (P1B, P1C, and P2A)                  |     |
|     | 15.6  | General-Purpose Output Ports (P0E and P0F)                        | 195 |
|     |       |                                                                   |     |
| 16. |       | ONVERTER (ADC)                                                    |     |
|     | 16.1  | Configuration of A/D Converter                                    |     |
|     | 16.2  | Functional Outline of A/D Converter                               |     |
|     | 16.3  | Input Select Block                                                |     |
|     | 16.4  | Compare Voltage Generation Block                                  | 201 |
|     | 16.5  | Compare Block                                                     |     |
|     | 16.6  | Performances of A/D Converter                                     | 205 |
|     | 16.7  | Using A/D Converter                                               | 206 |
|     | 16.8  | Notes on Using A/D Converter                                      | 211 |
|     | 16.9  | Status on Reset                                                   | 211 |
|     |       |                                                                   |     |
| 17. | D/A C | ONVERTER (DAC)                                                    | 212 |
|     | 17.1  | Configuration of D/A Converter                                    | 212 |
|     | 17.2  | Functional Outline of D/A Converter                               | 212 |
|     | 17.3  | Output Select Blocks                                              |     |
|     | 17.4  | Duty Setting Blocks and Clock Generation Block                    |     |
|     | 17.5  | Status on Reset                                                   |     |
|     |       |                                                                   |     |
| 18. | BEEP  | OUTPUT                                                            | 218 |
|     | 18.1  | Method of BEEP Output                                             |     |
|     | 18.2  | Output Waveform of BEEP                                           |     |
|     | 18.3  | Status on Reset                                                   |     |
|     | 18.4  | Notes on Using BEEP Function                                      |     |
|     |       |                                                                   |     |

| 19. | SERIA | L INTERFACE                                                |     |
|-----|-------|------------------------------------------------------------|-----|
|     | 19.1  | Configuration of Serial Interface                          | 222 |
|     | 19.2  | Functional Outline of Serial Interface                     | 223 |
|     | 19.3  | Shift Clock and Serial Data I/O Pin Control Blocks         | 224 |
|     | 19.4  | Clock Generation Block                                     |     |
|     | 19.5  | Clock Counter                                              |     |
|     | 19.6  | Presettable Shift Register (SIO1SFR)                       | 229 |
|     | 19.7  | Wait Block                                                 |     |
|     | 19.8  | Using Serial Interface                                     |     |
|     |       |                                                            |     |
|     | 19.9  | Status of Serial Interface on Reset                        | 240 |
| 20. | FREQ  | UENCY COUNTER (FC)                                         | 241 |
|     | 20.1  | Configuration of Frequency Counter                         | 241 |
|     | 20.2  | Functional Outline of Frequency Counter                    |     |
|     | 20.3  | Input Select Block and Gate Time Control Block             |     |
|     | 20.4  | Start/Stop Control Block and IF Counter                    |     |
|     | 20.5  | Using IF Counter Function                                  |     |
|     | 20.6  | Status on Reset                                            |     |
|     |       |                                                            |     |
|     | 20.7  | Notes on Using Frequency Counter                           | 256 |
| 21. | LCD C | ONTROLLER/DRIVER                                           | 258 |
|     | 21.1  | Configuration of LCD Controller/Driver                     | 258 |
|     | 21.2  | Functional Outline of LCD Controller/Driver                | 259 |
|     | 21.3  | LCD Segment Register                                       |     |
|     | 21.4  | Output Timing Control Blocks and Segment/Port Select Block |     |
|     | 21.5  | Using LCD Controller/Driver                                |     |
|     | 21.6  | Status on Reset                                            |     |
|     | 21.0  | Otatus on Neset                                            | 217 |
| 22. | KEY S | OURCE CONTROLLER/DECODER                                   | 275 |
|     | 22.1  | Configuration of Key Source Controller/Decoder             | 275 |
|     | 22.2  | Functional Outline of Key Source Controller/Decoder        | 276 |
|     | 22.3  | Key Source Data Setting Block                              |     |
|     | 22.4  | Output Timing Control Blocks and Segment/Port Select Block |     |
|     | 22.5  | Key Input Control Block                                    |     |
|     | 22.6  | Using Key Source Controller/Decoder                        |     |
|     | 22.7  | Status on Reset                                            |     |
|     |       |                                                            |     |
| 23. | _     | UCTION SET                                                 |     |
|     | 23.1  | Outline of Instruction Set                                 |     |
|     | 23.2  | Legend                                                     | 296 |
|     | 23.3  | Instruction Set List                                       | 297 |
|     | 23.4  | Assembler (AS17K) Embedded Macroinstruction                | 299 |
|     | 23.5  | Software Macroinstructions                                 |     |
| 0.4 | DESE  | DVED CVMDOL                                                | 200 |
| 24. |       | RVED SYMBOL                                                |     |
|     | 24.1  | Data Buffer (DBF)                                          |     |
|     | 24.2  | System Register (SYSREG)                                   |     |
|     | 24.3  | LCD Segment Register                                       |     |
|     | 24.4  | Port Register                                              |     |
|     | 24.5  | Register File (control register)                           |     |
|     | 24.6  | Peripheral Hardware Register                               |     |
|     | 24.7  | Others                                                     | 306 |

**NEC** 

| 25. ELECTRICAL SPECIFICATIONS                                                | 307 |
|------------------------------------------------------------------------------|-----|
| 26. PACKAGE                                                                  | 310 |
| 27. RECOMMENDED SOLDERING CONDITIONS                                         | 312 |
| APPENDIX A. NOTE ON CONNECTING CRYSTAL RESONATOR                             | 313 |
| APPENDIX B. DIFFERENCES AMONG $\mu$ PD17016, 17017, 17003A, 17005, AND 17010 | 314 |
| APPENDIX C. DEVELOPMENT TOOLS                                                | 319 |



## 1. PIN FUNCTIONS

## 1.1 Pin Function List

| Pin No.            | Symbol                                                                                    | Function                                                                                                                                                                                                                                                                 | Output Form                                                                                                                         | On Power-ON Reset                              |
|--------------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|
| 79<br>80<br>1<br>2 | P0C <sub>3</sub><br>P0C <sub>2</sub><br>P0C <sub>1</sub><br>P0C <sub>0</sub>              | 4-bit I/O port.  Can be set in input or output mode in 4-bit units.                                                                                                                                                                                                      | CMOS<br>push-pull                                                                                                                   | Input                                          |
| 3<br>4<br>5<br>6   | P0A <sub>3</sub> Note<br>P0A <sub>2</sub> Note<br>P0A <sub>1</sub><br>P0A <sub>0</sub>    | 4-bit I/O port.  Can be set in input or output mode in 1-bit units.                                                                                                                                                                                                      | N-ch<br>open drain,<br>5 V<br>(P0A <sub>3</sub> , P0A <sub>2</sub> )<br>CMOS<br>push-pull<br>(P0A <sub>1</sub> , P0A <sub>0</sub> ) | Input                                          |
| 7<br>8<br>9<br>10  | P0B <sub>3</sub><br>P0B <sub>2</sub> /SCK<br>P0B <sub>1</sub> /SO<br>P0B <sub>0</sub> /SI | Port 0B and serial interface I/O.  • P0B <sub>3</sub> -P0B <sub>0</sub> • 4-bit CMOS I/O port  • Can be set in input or output mode in 1-bit units  • SCK, SO, SI  • SCK : serial clock I/O  • SO : serial data output  • SI : serial data input                         | CMOS push-pull  P0B3, P0B2/SCK, P0B1/SO P0B0                                                                                        | Input<br>(P0B <sub>3</sub> -P0B <sub>0</sub> ) |
| 11                 | IC <sub>0</sub>                                                                           | Internally connected. Connect this pin to VDD or GND via resistor.                                                                                                                                                                                                       | -                                                                                                                                   | -                                              |
| 12                 | INT <sub>0</sub>                                                                          | Edge-detectable vectored interrupt input (rising edge detection).  This pin is a Schmitt trigger input pin with hysteresis characteristics.  Do not apply a voltage higher than Vod to INTo pin on power application; otherwise, normal operation will not be performed. | -                                                                                                                                   | Input                                          |

**Note** The P0A<sub>3</sub> and P0B<sub>2</sub> pins are N-ch open-drain output pins and must be connected to an external pull-up resistor.



| Pin No.              | Symbol                                                                                                                                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Output Form                                                                  | On Power-ON Reset                                                  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------|
| 13                   | CE                                                                                                                                    | <ul> <li>Selects operation of μPD17017 and inputs reset signal.</li> <li>(1) Device operation selection     PLL frequency synthesizer can operate when CE pin is high; it is automatically disabled (operation prohibited) while CE pin is low.</li> <li>(2) Reset signal input     When CE pin goes high, device is reset in synchronization with internal basic timer 0 carry FF (CE reset).     This pin does not accept low or high level of less than 110 to 165 μs to prevent malfunctioning due to noise.     Input signal level of this pin can be detected by CE pin level judge register of register file (address 07H).     Contents of CE pin level judge register are not changed by low or high level of less than 110 to 165 μs. This pin is a Schmitt trigger input pin with hysteresis characteristics.     Do not apply voltage higher than VDD to this pin on power application; otherwise, normal operation will not be performed.</li> </ul> | _                                                                            | Input                                                              |
| 14<br> <br>17        | P1A <sub>3</sub><br> <br>  P1A <sub>0</sub>                                                                                           | 4-bit CMOS I/O port.  Can be set in input or output mode in 1-bit units.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | CMOS<br>push-pull                                                            | Input                                                              |
| 18<br>19<br>20<br>21 | P1B <sub>3</sub> Note<br>P1B <sub>2</sub> /PWM <sub>1</sub> Note<br>P1B <sub>1</sub> /PWM <sub>0</sub> Note<br>P1B <sub>0</sub> /BEEP | Port 1B also serving as D/A converter and buzzer output pins.  • P1B <sub>3</sub> -P1B <sub>0</sub> • 4-bit output port  • PWM <sub>1</sub> , PWM <sub>0</sub> • D/A converter output with 8-bit resolution  • BEEP  • Buzzer output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | N-ch open drain, 16 V P1B3, P1B2/PWM1, P1B1/PWM0  CMOS push-pull (P1B0/BEEP) | Outpus<br>undefined data<br>(P1B <sub>3</sub> -P1-B <sub>0</sub> ) |
| 22<br> <br> <br>25   | P1C <sub>3</sub><br> <br>  P1C <sub>0</sub>                                                                                           | 4-bit CMOS output port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | CMOS<br>push-pull                                                            | Outputs<br>undefined data                                          |

**Note** The P1B<sub>3</sub>, P1B<sub>2</sub>/PWM<sub>1</sub>, and P1B<sub>1</sub>/PWM<sub>0</sub> pins are N-ch open-drain output pins and must be connected to an external pull-up resistor.



| Pin No.              | Symbol                                                                                                                         |                                                                                                                                                                                                                                               | Function                                                                                                                                                                                                                                                    |                     | Output Form                                    | On Power-ON Reset |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------------------------------------|-------------------|
| 26<br>27<br>28<br>29 | P1D <sub>3</sub> /FMIFC<br>P1D <sub>2</sub> /AMIFC<br>P1D <sub>1</sub> /ADC <sub>1</sub><br>P1D <sub>0</sub> /ADC <sub>0</sub> | converter.  • P1D <sub>3</sub> -P1D <sub>0</sub> • 4-bit input port  • FMIFC, AMIFC                                                                                                                                                           | d AM intermediate frequency                                                                                                                                                                                                                                 | _                   | Input<br>(P1D <sub>3</sub> -P1D <sub>0</sub> ) |                   |
|                      |                                                                                                                                |                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                             |                     |                                                |                   |
|                      |                                                                                                                                | P1D <sub>2</sub> /AMIFC                                                                                                                                                                                                                       | 0.1-1<br>0.44-0.46                                                                                                                                                                                                                                          | 0.06<br>0.3<br>0.05 |                                                |                   |
|                      |                                                                                                                                | C amplifier, cut DC apacitor.                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                             |                     |                                                |                   |
| 30<br>41             | VDD1<br>VDD2                                                                                                                   | Positive power sup when CPU and peretained at 2.2 V v μPD17017 is reset Do not apply voltato all pins other the raising V <sub>DD</sub> and CE may occur.  Apply same voltag V <sub>DD2</sub> supplies power X <sub>OUT</sub> pins) and error | A/D converter with 6 oply pins. Supply 5 \ ripheral functions op when clock is stopped by internal power-O ge higher than VoD pins. Especial pins simultaneously e to VoD1 and VoD2 pier to crystal oscillation out circuit (EO0 and power to other circuit | _                   | -                                              |                   |



| Pin No.  | Symbol                               | Function                                                                                                                                                                          |                                                                                  |                                                          |                                      | Output Form                   | On Power-ON Reset |
|----------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------|-------------------------------|-------------------|
| 31<br>32 | VCOL<br>VCOH                         | Inputs local oscillati<br>division modes are<br>pulse swallow (HF a                                                                                                               | available: di                                                                    | -                                                        | Input                                |                               |                   |
|          |                                      | Division Mode                                                                                                                                                                     | Input Pin                                                                        | Input Frequency<br>(MHz)                                 | Input Voltage<br>(V <sub>p-p</sub> ) |                               |                   |
|          |                                      | Direct division (MF)                                                                                                                                                              | VCOL                                                                             | 0.5-30                                                   | 0.2                                  |                               |                   |
|          |                                      | Pulse swallow (HF)                                                                                                                                                                | VCOL                                                                             | 5-40                                                     | 0.2                                  |                               |                   |
|          |                                      | Pulse swallow (VHF)                                                                                                                                                               | VCOH                                                                             | 9-150                                                    | 0.2                                  |                               |                   |
|          |                                      | Because these pins components of inpu                                                                                                                                             |                                                                                  |                                                          |                                      |                               |                   |
| 33       | GND                                  | Ground                                                                                                                                                                            |                                                                                  |                                                          |                                      | _                             | _                 |
| 34       | X <sub>OUT</sub> Note                | Crystal resonator co                                                                                                                                                              | • .                                                                              |                                                          | e pins.                              | CMOS<br>push-pull             | _                 |
| 35       | X <sub>IN</sub> Note                 |                                                                                                                                                                                   |                                                                                  |                                                          | _                                    |                               |                   |
| 36<br>37 | EO <sub>0</sub><br>EO <sub>1</sub>   | Output from charge If value resulting fro frequency input to \( \) higher than reference high level; if it is low frequencies coincide Because EO <sub>0</sub> and E can be used. | m dividing lot<br>/COL (pin 3/<br>ce frequency<br>ver, these pinse, these pinse. | i (VCO)<br>in 32) pin is<br>pins output<br>level. If two | CMOS 3-state                         | High impedance                |                   |
| 38       | IC <sub>1</sub>                      | Internally connected resistor.                                                                                                                                                    | I pin. Conne                                                                     | V <sub>DD</sub> via                                      | _                                    | -                             |                   |
| 39<br>40 | IC <sub>2</sub><br>IC <sub>3</sub>   | Internally connected                                                                                                                                                              | l pins. Leav                                                                     | inconnected.                                             | -                                    | -                             |                   |
| 42       | IC <sub>2</sub>                      | 1-bit CMOS output                                                                                                                                                                 | port.                                                                            |                                                          | CMOS<br>push-pull                    | Outputs<br>undefined<br>data. |                   |
| 43<br>44 | COM <sub>1</sub><br>COM <sub>0</sub> | Output common sig<br>These pins output lo<br>reset or clock stop i                                                                                                                | ow level on                                                                      | ower-ON                                                  | CMOS3<br>ternary output              | Low-level output              |                   |

Note Refer to APPENDIX A. NOTES ON CONNECTING CRYSTAL RESONATOR.



| Pin No. | Symbol                              | Function                                                    | Output Form | On Power-ON Reset                      |
|---------|-------------------------------------|-------------------------------------------------------------|-------------|----------------------------------------|
| 45      | LCD <sub>29</sub> /P0F <sub>3</sub> | Port 0F, port 0E, segment signal output pins of LCD         | CMOS        | Low-level output                       |
|         | I                                   | controller/driver, and key source signal output pins of key | push-pull   | (LCD <sub>29</sub> -LCD <sub>0</sub> ) |
| 48      | LCD <sub>26</sub> /P0F <sub>0</sub> | matrix.                                                     |             |                                        |
| 49      | LCD <sub>25</sub> /P0E <sub>3</sub> | <ul> <li>P0F₃-P0F₀</li> </ul>                               |             |                                        |
|         | I                                   | 4-bit CMOS output port                                      |             |                                        |
| 52      | LCD <sub>22</sub> /P0E <sub>0</sub> | ● P0E <sub>3</sub> -P0E <sub>0</sub>                        |             |                                        |
| 53      | LCD <sub>21</sub>                   | 4-bit CMOS output port                                      |             |                                        |
|         | I                                   | • LCD <sub>29</sub> -LCD <sub>0</sub>                       |             |                                        |
| 58      | LCD <sub>16</sub>                   | Segment signal output of LCD controller/driver.             |             |                                        |
| 59      | LCD <sub>15</sub> /KS <sub>15</sub> | • KS <sub>15</sub> -KS <sub>0</sub>                         |             |                                        |
|         | I                                   | Key source signal output of key matrix.                     |             |                                        |
| 74      | LCD <sub>0</sub> /KS <sub>0</sub>   |                                                             |             |                                        |
| 75      | P0D₃/ADC₅                           | Port 0D, analog input to A/D converter, and key source      | _           | Input with                             |
|         | I                                   | signal return input of LCD segment.                         |             | pull-down resistor                     |
| 78      | P0D <sub>0</sub> /ADC <sub>2</sub>  | ● P0D₃-P0D₀                                                 |             | (P0D <sub>3</sub> -P0D <sub>0</sub> )  |
|         |                                     | 4-bit input port                                            |             |                                        |
|         |                                     | Internal pull-down resistor is always ON.                   |             |                                        |
|         |                                     | • ADC <sub>5</sub> -ADC <sub>2</sub>                        |             |                                        |
|         |                                     | Analog input to A/D converter with 6-bit resolution.        |             |                                        |
|         |                                     | Internal pull-down resistor is OFF.                         |             |                                        |
|         |                                     | Key source return input                                     |             |                                        |
|         |                                     | Internal pull-down resistor is ON only while key source     |             |                                        |
|         |                                     | is output (220 $\mu$ s) if LCD segment pin is used as key   |             |                                        |
| 1       |                                     | source, and OFF while LCD segment signal is output.         |             |                                        |



## 1.2 Notes on Using General-Purpose Port

### 1.2.1 Data bit of port register

Input data of ports 0A, 0B, 0C, 0D, 1A, 1B, 1C, 1D, and 2A are read, and output data is set to these ports via the respective port registers (P0A through P2A registers) on data memory.

The P0A<sub>3</sub> pin of port 0A correspond to the most significant bit of port register P0A, and the P0A<sub>0</sub> pins correspond to the least significant bit.

Likewise, the pins of the other ports, ports 0B, 0C, 0D, 1A, 1B, 1C, 1D, and 2A, correspond to the bits of the respective port registers.

The output data of ports 0E and 0F are set by the LCD segment register on data memory.

## 1.2.2 I/O ports (ports 0A, 0B, 0C, and 1A)

#### (1) When each port is set in input mode

The status of each port pin is used as the value of the corresponding port register when an instruction that reads the contents of each port register on data memory is executed (when the address of a port register is specified as m of an instruction such as SKT m, #n4 and ADD r, m).

When an instruction that writes data to each port register is executed (when a port register address is specified as r of an instruction such as MOV m, #n4 and ADD r, m), the value of the corresponding port is written to the output data latch circuit.

## (2) When each port is set in output mode

When an instruction that writes data to each port register is executed, the value of the data is written to the data latch circuit, and output from the corresponding port pins.

When an instruction that reads the contents of each port register is executed, the contents of the output data latch are used as the value of the port register. When an instruction that reads the contents of the port register corresponding to the P0A<sub>3</sub> and P0A<sub>2</sub> pins is executed, the statuses of the pins, which may be different from the output data, are read as is.

All these port pins are set in the input mode on power-ON reset, CE reset, and execution of the clock stop instruction.

Because the contents of the output data latch circuit are undefined on power-ON reset, undefined data may be output unless an instruction that writes data to the port register is executed before a port is set in the output mode. The contents of the output data latch circuit are not affected by CE reset or execution of the clock stop instruction.

## 1.2.3 Output ports (ports 1B, 1C, 0F, 0E, and 2A)

An output port writes the value of the corresponding port register to the output data latch circuit and outputs it from each port pin when an instruction that writes data to the port register is executed.

When an instruction that reads the value of the port register is executed, the status of the output data latch circuit is used as the value of the port register.

Undefined data is output on power-ON reset.

The current output data is retained on CE reset and execution of the clock stop instruction. However, ports 0E and 0F automatically output low levels on power-ON reset and execution of the clock stop instruction.



## 1.3 Equivalent Circuits of Pins





**Note** The  $\overline{\text{RESET}}$  signal is not supplied to P0C.

## (2) P0A (P0A<sub>3</sub>, P0A<sub>2</sub>) (I/O)





(3) P1B (P1B<sub>0</sub>/BEEP) P1C (P1C<sub>3</sub>, P1C<sub>2</sub>, P1C<sub>1</sub>, P1C<sub>0</sub>) P2A (P2A<sub>0</sub>) LCD<sub>0</sub>/KS<sub>0</sub>-LCD<sub>29</sub>/P0F<sub>3</sub> (Output)



(4) P1B (P1B<sub>3</sub>, P1B<sub>2</sub>/PWM<sub>1</sub>, P1B<sub>1</sub>/PWM<sub>0</sub>) (Output)



(5) P0D (P0D<sub>3</sub>/ADC<sub>5</sub>, P0D<sub>2</sub>/ADC<sub>4</sub>, P0D<sub>1</sub>/ADC<sub>3</sub>, P0D<sub>0</sub>/ADC<sub>2</sub>) (Input)



(6) P1D (P1D<sub>1</sub>/ADC<sub>1</sub>, P1D<sub>0</sub>/ADC<sub>0</sub>) (Input)





## (7) P1D (P1D<sub>3</sub>/FMIFC, P1D<sub>2</sub>/AMIFC) (Input)



## (8) CE | (Schmitt trigger input)



## (9) XOUT (output), XIN (input)



 $\begin{array}{c} \text{(10) EO}_1 \\ \text{EO}_0 \end{array} \right\} \text{ (output)}$ 



 $\begin{array}{c} \text{(11) COM}_1 \\ \text{COM}_0 \end{array} \right\} \text{ (output)}$ 



(12) VCOH VCOL (input)





## 1.4 Processing of Unused Pins

It is recommended that unused pins be processed as follows:

Table 1-1. Processing of Unused Pins

| Pin Name  |                                                                                                                | I/O Mode               | Recommended Processing                                                                                        |  |  |  |  |  |  |
|-----------|----------------------------------------------------------------------------------------------------------------|------------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Port pins | P0A <sub>0</sub> -P0A <sub>3</sub>                                                                             | I/ONote 1              | Set general-purpose input port mode by software, and                                                          |  |  |  |  |  |  |
|           | P0B <sub>0</sub> /SI                                                                                           |                        | connect each port pin to VDD or GND via resistorNote 2.                                                       |  |  |  |  |  |  |
|           | P0B <sub>1</sub> /SO                                                                                           |                        |                                                                                                               |  |  |  |  |  |  |
|           | P0B <sub>2</sub> /SCK                                                                                          |                        |                                                                                                               |  |  |  |  |  |  |
|           | P0B <sub>3</sub>                                                                                               |                        |                                                                                                               |  |  |  |  |  |  |
|           | P0C <sub>0</sub> -P0C <sub>3</sub>                                                                             |                        |                                                                                                               |  |  |  |  |  |  |
|           | P0D <sub>0</sub> /ADC <sub>2</sub> -P0D <sub>3</sub> /ADC <sub>5</sub>                                         | Input                  | Connect each port pin to GND via resistor <sup>Note 2</sup> .                                                 |  |  |  |  |  |  |
|           | P0E <sub>0</sub> /LCD <sub>22</sub> -P0E <sub>3</sub> /LCD <sub>25</sub>                                       | CMOS push-pull output  | Open                                                                                                          |  |  |  |  |  |  |
|           | P0F <sub>0</sub> /LCD <sub>26</sub> -P0F <sub>3</sub> /LCD <sub>29</sub>                                       |                        |                                                                                                               |  |  |  |  |  |  |
|           | P1A <sub>0</sub> -P1A <sub>3</sub>                                                                             | I/ONote 1              | Set general-purpose input port mode by software, and connect each port pin to VDD or GND via resistor Note 2. |  |  |  |  |  |  |
|           | P1B <sub>0</sub> /BEEP                                                                                         | CMOS push-pull output  | Open                                                                                                          |  |  |  |  |  |  |
|           | P1B <sub>1</sub> /PWM <sub>0</sub> , P1B <sub>2</sub> /PWM <sub>1</sub><br>P1B <sub>3</sub>                    | N-ch open drain output | Set low-level output by software and leave port pins open.                                                    |  |  |  |  |  |  |
|           | P1C <sub>0</sub> -P1C <sub>3</sub>                                                                             | CMOS push-pull output  | Open                                                                                                          |  |  |  |  |  |  |
|           | P1D <sub>0</sub> /ADC <sub>0</sub> , P1D <sub>1</sub> /ADC <sub>1</sub>                                        | Input                  | Connect each pin to V <sub>DD</sub> or GND via resistor <sup>Note 2</sup> .                                   |  |  |  |  |  |  |
|           | P1D <sub>2</sub> /AMIFC <sup>Note 3</sup>                                                                      |                        | Set port mode and connect each pin to V <sub>DD</sub> or GND via                                              |  |  |  |  |  |  |
|           | P1D <sub>3</sub> /FMIFC <sup>Note 3</sup>                                                                      |                        | resistor <sup>Note 2</sup> .                                                                                  |  |  |  |  |  |  |
|           | P2A <sub>0</sub> CMOS push-pull outpu                                                                          |                        | t Open                                                                                                        |  |  |  |  |  |  |
| Pins      | CE                                                                                                             | Input                  | Connect to V <sub>DD</sub> via resistor <sup>Note 2</sup> .                                                   |  |  |  |  |  |  |
| other     | COM <sub>0</sub> , COM <sub>1</sub>                                                                            | Output                 | Open                                                                                                          |  |  |  |  |  |  |
| than port | EO <sub>0</sub> , EO <sub>1</sub>                                                                              | Output                 | Open                                                                                                          |  |  |  |  |  |  |
|           | IC <sub>0</sub>                                                                                                | _                      | Connect to VDD or GND via resistorNote 2.                                                                     |  |  |  |  |  |  |
|           | IC <sub>1</sub>                                                                                                | _                      | Connect to V <sub>DD</sub> via resistor <sup>Note 2</sup> .                                                   |  |  |  |  |  |  |
|           | IC <sub>2</sub> , IC <sub>3</sub>                                                                              | _                      | Open                                                                                                          |  |  |  |  |  |  |
|           | INTo                                                                                                           | Input                  | Connect to V <sub>DD</sub> or GND via resistor <sup>Note 2</sup> .                                            |  |  |  |  |  |  |
|           | LCD <sub>0</sub> /KS <sub>0</sub> -LCD <sub>15</sub> /KS <sub>15</sub><br>LCD <sub>16</sub> -LCD <sub>21</sub> | Output                 | Open                                                                                                          |  |  |  |  |  |  |
|           | VCOH, VCOL                                                                                                     | Input                  | Disable PLL by software and leave pins open.                                                                  |  |  |  |  |  |  |

- **Notes 1.** The I/O port pins are set in the input mode on power application, execution of the clock stop instruction, or CE reset.
  - 2. If a port pin is externally pulled up (connect to  $V_{DD}$  via resistor) or down (connect to GND via resistor) with a high resistance, the pin almost goes into a high-impedance state, and the current consumption (inrush current) of the port pin increases. Generally, the pull-up and pull-down resistances are several 10 k $\Omega$ , although they vary depending on the application circuit.
  - 3. Do not set these pins as AMIFC and FMIFC modes; otherwise, the current consumption will increase.

## 1.5 Notes on Using CE and INTo Pins

The CE and INT<sub>0</sub> pins have a function to set a test mode (for IC test) in which the internal operations of the  $\mu$ PD17017 are tested, in addition to the functions listed in **1.1 Pin Function List**.

If a voltage higher than V<sub>DD</sub> is applied to either of these pins, the test mode is set. Therefore, if noise exceeding V<sub>DD</sub> is applied to these pins even during normal operation, the test mode is set by mistake, affecting the normal operation.

Noise may be superimposed on these pins if the length of the wiring of these pins is too long.

Therefore, keep the wiring length as short as possible. If noise is inevitable, take noise suppression measures by using an external component as illustrated below.

Connect diode with low V<sub>F</sub>
 between CE or INT<sub>0</sub> and V<sub>DD</sub>

• Connect capacitor between CE or INT₀ and VDD







## 2. PROGRAM MEMORY (ROM)

## 2.1 Outline of Program Memory

Figure 2-1 outlines the program memory.

As shown in this figure, the program memory consists of a program memory and a program counter.

The addresses of the program memory are specified by the program counter.

The program memory has the following two major functions.

- (1) Stores programs.
- (2) Stores constant data

Figure 2-1. Outline of Program Memory



## 2.2 Program Memory

Figure 2-2 shows the configuration of the program memory.

As shown in this figure, the program memory is configured as follows:

 $\mu$ PD17016: 3836 × 16 bits (0000H through 0EFBH)

 $\mu$ PD17017: 7932 × 16 bits (0000H through 1EFBH)

All "instructions" are "1-word instructions" 16 bits long, so that one instruction can be stored in one address of the program memory.

Constant data reads the contents of the program memory to the data buffer by using a table reference instruction.

Figure 2-2. Configuration of Program Memory

Address 0000H (with  $\mu$ PD17017) (with  $\mu$ PD17016) Reset start address BR addr instruction 0001H branch addressNote BR addr instruction 0002H BR @AR instruction branch address branch address 0003H Timer interrupt vector CALL addr Page 0 instruction BR @AR instruction CALL @AR instruction 0004H subroutine branch address subroutine entry entry address 0005H address INTo pin interrupt vector CALL @AR instruction MOVT DBF, @AR instruction subroutine entry table reference address address 00FFH MOVT DBF, @AR instruction 07FFH table reference address Page 1 (with  $\mu$ PD17016) 0EFBH 0FFFH Page 2 17FFH Page 3 (with  $\mu$ PD17017) 1EFBH 16 bits

Note Valid in the address 0000H through 0EFBH.



## 2.3 Program Counter

Figure 2-3 shows the configuration of the program counter.

The program counter specifies an address of the program memory.

Bit PC<sub>11</sub> of the  $\mu$ PD17016, and PC<sub>11</sub> and PC<sub>12</sub> of the  $\mu$ PD17017 indicate a page.

Figure 2-3. Configuration of Program Counter



## 2.4 Program Flow

The execution flow of the program is controlled by the program counter which specifies an address of the program memory.

Figure 2-4 shows the value set to the program counter when each instruction is executed.

Table 2-1 shows a vector address when an interrupt is acknowledged.



Figure 2-4. Specification of Program Counter on Execution of Each Instruction

## (a) $\mu$ PD17016

| Program counter                |               |    | Contents of program counter (PC)                  |                            |                |                |                |            |                |    |                |                |                |
|--------------------------------|---------------|----|---------------------------------------------------|----------------------------|----------------|----------------|----------------|------------|----------------|----|----------------|----------------|----------------|
| Instruction                    |               |    | b <sub>10</sub>                                   | <b>b</b> 9                 | b <sub>8</sub> | b <sub>7</sub> | b <sub>6</sub> | <b>b</b> 5 | b <sub>4</sub> | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> |
| BR addr Page 0                 |               | 0  | Instruction engrand (addr)                        |                            |                |                |                |            |                |    |                |                |                |
|                                | Page 1        | 1  | Instruction operand (addr)                        |                            |                |                |                |            |                |    |                |                |                |
| CALL addr                      |               | 0  | Instruction operand (addr)                        |                            |                |                |                |            |                |    |                |                |                |
|                                |               |    | _                                                 |                            |                |                |                |            |                | -  |                |                |                |
| BR @AR                         |               | 0  | 0                                                 | 0                          | 0              |                |                |            |                |    |                |                |                |
| CALL @AR                       | CALL @AR      |    |                                                   | Adddress register contents |                |                |                |            |                |    |                |                |                |
| MOVT DBF, @AR                  | MOVT DBF, @AR |    |                                                   |                            |                |                |                |            |                |    |                |                |                |
| RET                            |               | Co | ontents of address stack register (ASR) specified |                            |                |                |                |            |                |    |                |                |                |
| RETSK                          |               | by | y stack pointer (SP)                              |                            |                |                |                |            |                |    |                |                |                |
| RETI                           |               |    | (Return address)                                  |                            |                |                |                |            |                |    |                |                |                |
| When interrupt is acknowledged |               |    | Vector address of each interrupt                  |                            |                |                |                |            |                | •  |                |                |                |
| Power-ON reset, CE reset       |               |    | 0                                                 | 0                          | 0              | 0              | 0              | 0          | 0              | 0  | 0              | 0              | 0              |

## (b) $\mu$ PD17017

| Prog                           | Contents of program counter (PC) |                                                    |                  |                            |                            |                |                |                |                |            |                |                |                |   |
|--------------------------------|----------------------------------|----------------------------------------------------|------------------|----------------------------|----------------------------|----------------|----------------|----------------|----------------|------------|----------------|----------------|----------------|---|
| Instruction                    | b <sub>12</sub>                  | b <sub>11</sub>                                    | <b>b</b> 10      | <b>b</b> 9                 | b <sub>8</sub>             | b <sub>7</sub> | b <sub>6</sub> | b <sub>5</sub> | b <sub>4</sub> | <b>b</b> з | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> |   |
| BR addr                        | Page 0                           | 0                                                  | 0                |                            |                            |                |                |                |                |            | '              |                |                |   |
| Page 1<br>Page 2               |                                  | 0                                                  | 1                |                            |                            |                |                |                |                |            |                |                |                |   |
|                                |                                  | 1                                                  | 0                | -                          | Instruction operand (addr) |                |                |                |                |            |                |                |                |   |
|                                | Page 3                           | 1                                                  | 1                |                            |                            |                |                |                |                |            |                |                |                |   |
| CALL addr                      |                                  |                                                    | 0                | Instruction operand (addr) |                            |                |                |                |                |            |                |                |                |   |
| BR @AR                         |                                  |                                                    |                  | 1                          |                            |                |                |                |                |            |                |                |                |   |
| CALL @AR                       |                                  | Adddress register contents                         |                  |                            |                            |                |                |                |                |            |                |                |                |   |
| MOVT DBF, @AR                  |                                  |                                                    |                  |                            |                            |                |                |                |                |            |                |                |                |   |
| RET                            |                                  | Contents of address stack register (ASR) specified |                  |                            |                            |                |                |                |                |            |                |                |                |   |
| RETSK                          |                                  | by stack pointer (SP)                              |                  |                            |                            |                |                |                |                |            |                |                |                |   |
| RETI                           |                                  |                                                    | (Return address) |                            |                            |                |                |                |                |            |                |                |                |   |
| When interrupt is acknowledged |                                  |                                                    |                  |                            | Vec                        | tor a          | ddres          | ss of          | each           | inter      | rupt           |                |                |   |
| Power-ON reset, CE reset       |                                  |                                                    | 0                | 0                          | 0                          | 0              | 0              | 0              | 0              | 0          | 0              | 0              | 0              | 0 |

•



**Table 2-1. Interrupt Vector Address** 

| Priority | Internal/External | Interrupt Source | Vector address |
|----------|-------------------|------------------|----------------|
| 1        | Internal          | INT₀ pin         | 0005H          |
| 2        | External          | Timer            | 0003H          |

## 2.5 Notes on Using Program Memory

The program memory of the  $\mu$ PD17016 does not have addresses 0EFCH through 0FFFH, and that of the  $\mu$ PD17017 does not have addresses 1EFCH through 1FFFH. Therefore, do not use an instruction that causes the value of the program counter to be set to these addresses.

## 3. ADDRESS STACK (ASK)

## 3.1 Outline of Address Stack

Figure 3-1 outlines the address stack.

The address stack consists of a stack pointer and address stack registers.

The addresses of the address stack registers are specified by the stack pointer.

The address stack saves a return address when a subroutine call instruction is executed or when an interrupt is acknowledged.

The address stack is also used when a table reference instruction is executed.

Figure 3-1. Outline of Address Stack



## 3.2 Address Stack Register (ASR)

Figure 3-2 shows the configuration of the address stack registers.

There are eight 16-bit address stack registers: ASR0 through ASR7. Actually, however, no register is assigned to ASR7, and seven registers, ASR0 through ASR6, are used.

The high-order 4 bits of ASR0 through ASR6 of the  $\mu$ PD17016 are fixed to "0", and the high-order 3 bits of the address stack registers of the  $\mu$ PD17017 are fixed to "0".

The address stack saves a return address when a subroutine call instruction or table reference instruction is executed, or when an interrupt is acknowledged.



Figure 3-2. Configuration of Address Stack Registers

## (a) $\mu$ PD17016



## **(b)** $\mu$ **PD17017**



## 3.3 Stack Pointer (SP)

## 3.3.1 Configuration and function of stack pointer

Figure 3-3 shows the configuration and function of the stack pointer.

The stack pointer is a 4-bit binary counter.

It specifies the address of an address stack register.

The value of the stack pointer can be directly read or written by using a register manipulation instruction.

Name Flag Symbol Address Read/ Write  $b_2$ b<sub>1</sub>  $b_0$ Stack pointer 0 S 01H R/W S S SP Ρ Ρ Ρ 2 0 1 Specifies address of address stack register (ASR) 0 : Address 0 (ASR0) Address 1 (ASR1) 0 0 1 0 1 0 Address 2 (ASR2) 0 1 | 1 Address 3 (ASR3) Address 4 (ASR4) 1 0 0 Address 5 (ASR5) 1 0 | 1 1 1 0 Address 6 (ASR6) 1 1 | 1 Address 7 (ASR7) Fixed to "0"

Figure 3-3. Configuration and Function of Stack Pointer

| et    | Power-ON   |  | ) | 1 |   | 1 | 1 |
|-------|------------|--|---|---|---|---|---|
| n res | Clock stop |  |   | 1 |   | 1 | 1 |
| Ō     | CE         |  |   | 1 | 1 | 1 | 1 |



## 3.4 Operation of Address Stack

## 3.4.1 On execution of subroutine call ("CALL addr", "CALL @AR") or return ("RET", "RETSK") instruction

When a subroutine call instruction is executed, the value of the stack pointer is decremented by one and a return address is saved to the address stack register specified by the stack pointer.

When a return instruction is executed, the contents (return address) of the address stack register specified by the stack pointer are restored to the program counter, and the value of the stack pointer is incremented by one.

#### 3.4.2 On execution of table reference instruction ("MOVT DBF, @AR")

When a table reference instruction is executed, the value of the stack pointer is decremented by one, and a return address is saved to the address stack register specified by the stack pointer.

Next, the contents of the program memory specified by the address register are read to the data buffer, the contents (return address) of the address stack register specified by the stack pointer are restored to the program counter, and then the value of the stack pointer is incremented by one.

## 3.4.3 On acknowledging interrupt and execution of return instruction ("RETI")

When an interrupt is acknowledged, the value of the stack pointer is decremented by one, and the return address is saved to the address stack register specified by the stack pointer.

When a return instruction is executed, the contents (return address) of the address stack register specified by the stack pointer are restored to the program counter, and the value of the stack pointer is incremented by one.

#### 3.4.4 On execution of address stack manipulation instruction ("PUSH AR", "POP AR")

When the "PUSH" instruction is executed, the value of the stack pointer is decremented by one, and the contents of the address register are transferred to the address stack register specified by the stack pointer.

When the "POP" instruction is executed, the contents of the address stack register specified by the stack pointer are transferred to the address register, and the value of the stack pointer is incremented by one.

## 3.5 Notes on Using Address Stack

## 3.5.1 Nesting level

The value of the address stack register (ASR7) is "undefined" when the value of the stack pointer is 07H. Do not use a subroutine call or interrupt exceeding level 7 without manipulating the stack; otherwise, execution returns to an "undefined address".

## 4. DATA MEMORY (RAM)

## 4.1 Outline of Data Memory

Figure 4-1 outlines the data memory.

As shown in this figure, the data memory consists of a general-purpose data memory, system register, data buffer, LCD segment register, and port registers.

The data memory stores data, transfers data with the peripheral hardware units, sets display data, transfers data with the ports, and controls the CPU.



Figure 4-1. Outline of Data Memory

**Note** BANK3 is not provided on the  $\mu$ PD17016.



## 4.2 Configuration and Function of Data Memory

Figure 4-2 shows the configuration of the data memory.

As shown in the figure, the data memory consists of banks.

Each bank consists of 128 nibbles with 7H row addresses and 0FH column addresses.

The data memory can be divided by classification of function into the blocks explained in the following 4.2.1 through 4.2.6.

The contents of the data memory can be operated, compared, judged, and transferred in 4-bit units by using a data memory manipulation instruction.

Table 4-1 lists the available data memory manipulation instructions.

## 4.2.1 System register (SYSREG)

The system register is allocated to addresses 74H through 7FH.

Because the system register is allocated to every bank, the identical system register exists at addresses 74H through 7FH of any bank.

For details, refer to 5. SYSTEM REGISTER (SYSREG).

## 4.2.2 Data buffer (DBF)

The data buffer is allocated to addresses 0CH through 0FH of BANK0.

For details, refer to 9. DATA BUFFER (DBF).

## 4.2.3 LCD segment data register (LCD segment register)

The LCD segment register is allocated to addresses 60H through 6FH of BANKO.

For details, refer to 21. LCD CONTROLLER/DRIVER.

#### 4.2.4 Port data registers (port registers)

The port registers are allocated to addresses 70H through 73H of each bank.

For details, refer to 15. GENERAL-PURPOSE PORT.

## 4.2.5 General-purpose data memory

The general-purpose data memory is allocated to the addresses of the data memory excluding those of the system register, LCD segment register, and port registers.

## (a) $\mu$ PD17016

The general-purpose data memory of the  $\mu$ PD17016 consists of a total of 320 nibbles (320 × 4 bits): 96 nibbles of BANK0, and 112 nibbles each of BANK1 and BANK2.

## (b) $\mu$ PD17017

The general-purpose data memory of the  $\mu$ PD17017 consists of a total of 432 nibbles (432 × 4 bits): 96 nibbles of BANK0, and 112 nibbles each of BANK1 through BANK3.

## 4.2.6 Data memory not provided

Data memory areas to which nothing is actually allocated exist in the LCD segment register and part of the port registers.

For the details of these data memory areas, refer to **4.4.2 Notes on data memory area not provided**, **15. GENERAL-PURPOSE PORT**, and **21. LCD CONTROLLER/DRIVER**.



Figure 4-2. Configuration of Data Memory

- **Notes 1.** BANK3 is not provided on the  $\mu$ PD17016.
  - 2. BANK3 does not have addresses 70H through 73H.



Table 4-1. Data Memory Manipulation Instructions

| Fund      | ction       | Instruction                 |
|-----------|-------------|-----------------------------|
| Operation | Addition    | ADD<br>ADDC                 |
|           | Subtraction | SUB<br>SUBC                 |
|           | Logical     | AND<br>OR<br>XOR            |
| Compare   |             | SKE<br>SKGE<br>SKLT<br>SKNE |
| Transfer  |             | MOV<br>LD<br>ST             |
| Judgement |             | SKT<br>SKF                  |

# 4.3 Addressing of Data Memory

Figure 4-3 shows addressing of the data memory.

An address of the data memory is specified by a bank, a row address, and a column address.

The row address and column address are directly specified by using a data memory manipulation instruction.

The bank is specified by the contents of the bank register.

For the details of the bank register, refer to 5. SYSTEM REGISTER (SYSREG).

Figure 4-3. Addressing of Data Memory



# 4.4 Notes on Using Data Memory

#### 4.4.1 On power-ON reset

The contents of the general-purpose data memory are "undefined" on power-ON reset. Initialize the general-purpose data memory as necessary.

# 4.4.2 Notes on data memory area not provided

If a data memory manipulation instruction is executed to an address of the data memory area not provided, the following operations are performed.

# (1) Device operation

If a read instruction is executed, "0" is read.

Nothing is affected even if a write instruction is executed.

# (2) Assembler operation

Assembly is performed normally. An "error" does not occur.

## (3) In-circuit emulator operation

If a read instruction is executed, "0" is read.

Nothing is affected even if a write instruction is executed.

An "error" does not occur.



## 5. SYSTEM REGISTER (SYSREG)

# 5.1 Outline of System Register

Figure 5-1 shows the location of the system memory on the data memory and the outline of the system register.

As shown in this figure, the system register is allocated to addresses 74H through 7FH of each bank of the data memory. Therefore, an identical system register exists at addresses 74H through 7FH of any bank.

Because the system register is located on the data memory, it can be manipulated by any data memory manipulation instruction.

The system register consists of seven registers.

Figure 5-1. Location on Data Memory and Outline of System Register



| Address  | 74H              | 75H             | 76H | 77H | 78H                 | 79H               |
|----------|------------------|-----------------|-----|-----|---------------------|-------------------|
| Name     | Address register |                 |     |     | Window register     | Bank register     |
|          | (AR)             |                 |     |     | (WR)                | (BANK)            |
| Function | Controls program | memory address. |     |     | Transfers data      | Specifies bank of |
|          |                  |                 |     |     | with register file. | data memory.      |

| Address  | 7AH                 | 7BH             | 7CH              | 7DH                                   | 7EH            | 7FH                 |
|----------|---------------------|-----------------|------------------|---------------------------------------|----------------|---------------------|
| Name     | Index register (IX) | )               | General register |                                       | Program status |                     |
|          | Data memory row     |                 |                  | pointer (KF)                          |                | (PSWORD)            |
| Function | Modifies address    | of data memory. |                  | Specifies address<br>general register | s of           | Controls operation. |

# 5.2 System Register List

Figure 5-2 shows the configuration of the system register.

Figure 5-2. Configuration of System Register

| Window<br>register<br>(WR)<br>WR                            | Bank<br>register<br>(BANK)<br>BANK    |
|-------------------------------------------------------------|---------------------------------------|
| register<br>(WR)                                            | register<br>(BANK)                    |
| (WR)                                                        | (BANK)                                |
|                                                             |                                       |
| WR                                                          | BANK                                  |
|                                                             |                                       |
| b <sub>3</sub> b <sub>2</sub> b <sub>1</sub> b <sub>0</sub> | b b b b b b b b b b b b b b b b b b b |
| -                                                           | 0 0                                   |
|                                                             | - 0 0                                 |
| <u>b</u><br><b>-</b>                                        | b b b b b b b b b b b b b b b b b b b |

| Address |                              | 7/             | λН             |                |        | 7E             | ЗН             |                 |      | 70             | CH             |             |            | 70             | Н              |            |       | 7E             | H              |                |             | 7F             | Н              |                |  |
|---------|------------------------------|----------------|----------------|----------------|--------|----------------|----------------|-----------------|------|----------------|----------------|-------------|------------|----------------|----------------|------------|-------|----------------|----------------|----------------|-------------|----------------|----------------|----------------|--|
| Name    |                              |                |                |                |        |                |                |                 |      | Sy             | stem           | regi        | ster       |                |                |            |       |                |                |                |             |                |                |                |  |
|         |                              | Index register |                |                |        |                |                |                 |      |                |                |             |            | •              | Gene           | eral re    | egist | er             |                |                | Prog        | ıram           | statu          | s              |  |
|         | Data memory row pointer (RP) |                |                |                |        |                |                |                 | word |                |                |             |            |                |                |            |       |                |                |                |             |                |                |                |  |
|         |                              | a              | addre          | ess po         | ointer | (MF            | P)             |                 |      |                |                |             |            |                |                |            |       |                |                | (PSWORD)       |             |                |                |                |  |
| Symbol  |                              | IX             | Ή              |                |        | IX             | M              |                 |      | I)             | (L             |             |            | RF             | РΗ             |            |       | RI             | PL             |                | PSW         |                |                |                |  |
|         |                              | М              | РΗ             |                |        | M              | PL             |                 |      |                |                |             |            |                |                |            |       |                |                |                |             |                |                |                |  |
| Bit     | bз                           | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | bз     | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub>  | bз   | b <sub>2</sub> | b <sub>1</sub> | bo          | bз         | b <sub>2</sub> | b <sub>1</sub> | bo         | bз    | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | bз          | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> |  |
| Data    |                              |                |                |                |        |                |                |                 |      |                |                |             |            |                |                |            |       |                |                |                |             |                |                |                |  |
|         | М                            | ,<br> <br>     |                |                |        |                |                |                 |      |                |                |             |            | !<br>!         | !              | ,<br> <br> |       |                | !<br>!<br>!    | В              | С           | С              | z              | 1              |  |
|         | Р                            | 0              | 0              | -              |        |                | !<br>!         | (I.             | x)   | <br>           | <br>           | -           | 0 0 0 (RP) |                |                |            | -     | С              | М              | Υ              | !<br>!<br>! | x              |                |                |  |
|         | Е                            | <br>           | <br>           |                | (M     | lP)            |                | <br>            |      | <br>           | <br>           | !<br>!      |            |                |                | <br>       | D     | Р              |                | !<br>!         | Е           |                |                |                |  |
|         |                              | <br>           | <br>           |                |        |                | <br> <br> <br> | 1<br> <br> <br> |      | <br>           | !<br>!<br>!    | !<br>!<br>! |            | <br>           | !<br>!<br>!    | <br>       |       | !<br>!<br>!    | <br>           |                |             |                | !<br>!<br>!    | <br>           |  |



# 5.3 Address Register (AR)

# 5.3.1 Configuration of address register

Figure 5-3 shows the configuration of the address register.

As shown in this figure, the address register consists of 16 bits, or 74H through 77H (AR3 through AR0) of the system register. The high-order 8 bits of this register of the  $\mu$ PD17016 are fixed to "0", and the high-order 3 bits of the address register of the  $\mu PD17017$  are fixed to "0".

Address 74H 75H 76H 77H Address register (AR) Name Symbol AR3 AR2 AR0  $b_2$ b<sub>1</sub> b<sub>1</sub> bз b<sub>2</sub> b<sub>1</sub>  $b_2$ b<sub>1</sub> Bit bз  $b_0$ bз  $b_2$  $b_0$  $b_0$ bз  $b_0$ DataNote ( $\mu$ PD17016) 0 0 0 0 0 0 0 î  $\widehat{\mathsf{M}}$ S S В ₿ (μPD17017) 0 0 0 î M S S ₿ ₿ Power-ON 0 0 0 0 On reset Clock stop 0 0 0 0

0

0

0

Figure 5-3. Configuration of Address Register

Remark Power-ON: power-ON reset

CE

Clock stop: execution of clock stop instruction

0

CE : CE reset

Note Bits marked "0" are fixed to 0.



#### 5.3.2 Function of address register

The address register specifies a program memory address when a table reference ("MOVT DBF, @AR"), stack manipulation ("PUSH AR", "POP AR"), indirect branch ("BR @AR") or indirect subroutine call ("CALL @AR") instruction is executed.

A dedicated instruction ("INC AR") that can increment the value of the address register by one is also available.

The following paragraphs (1) through (5) explain the operations to be performed when the respective instructions are executed.

The address register can set the following range of the program memory addresses.

 $\mu$ PD17016 : 0000H through 00FFH  $\mu$ PD17017 : 0000H through 1EFBH

Do not set an address other than above to the address register.

#### (1) Table reference instruction ("MOVT DBF, @AR")

This instruction reads the constant data (16-bit) of the program memory address specified by the contents of the address register to the data buffer.

# (2) Stack manipulation instructions ("PUSH AR", "POP AR")

When the "PUSH AR" instruction is executed, the value of the stack pointer is decremented by one, and the contents of the address register (AR) are stored to the address stack register specified by this value of the stack pointer.

When the "POP AR" instruction is executed, the contents of the address stack register specified by the stack pointer are transferred to the address register, and the value of the stack pointer are incremented by one.

# (3) Indirect branch instruction ("BR @AR")

This instruction branches execution to the program memory address specified by the contents of the address register.

## (4) Indirect subroutine call instruction ("CALL @AR")

This instruction calls the subroutine at the program memory address specified by the contents of the address register.

#### (5) Address register increment instruction ("INC AR")

This instruction increments the contents of the address register by one.

# (a) With $\mu$ PD17016

Because the address register of the  $\mu$ PD17016 consists of 8 bits, its contents are cleared to "0000H" if the "INC AR" instruction is executed when the contents of the address register are "00FFH".

## (b) With $\mu$ PD17017

Because the address register of the  $\mu$ PD17017 consists of 13 bits, its contents are cleared to "0000H" if the "INC AR" instruction is executed when the contents of the address register are "1FFFH".

## 5.3.3 Address register and data buffer

The address register can transfer data via the data buffer as part of the peripheral hardware.

For details, refer to 9. DATA BUFFER (DBF).



## 5.4 Window Register (WR)

## 5.4.1 Configuration of window register

Figure 5-4 shows the configuration of the window register.

As shown in the figure, the window register consists of 4 bits at address 78H of the system register.

78H Address Name Window register (WR) Symbol WR Bit bз b<sub>2</sub> b<sub>1</sub>  $b_0$ î Data  $\widehat{\mathsf{M}}$ S S В В Power-ON Undefined Clock stop Holds previous CE status

Figure 5-4. Configuration of Window Register

# 5.4.2 Function of window register

The window register is used to transfer data with register file (RF) that is explained later.

To transfer data between the window register and register file, dedicated instructions "PEEK WR, rf" and "POKE rf, WR" are used (rf: address of register file).

The following paragraphs (1) and (2) explain the operations to be performed when each of these instructions is executed.

Also refer to 8. REGISTER FILE (RF).

#### (1) "PEEK WR, rf" instruction

When this instruction is executed, the contents of the register file addressed by "rf" are transferred to the window register.

# (2) "POKE rf, WR" instruction

When this instruction is executed, the contents of the window register are transferred to the register file addressed by "rf".

## 5.5 Bank Register (BANK)

#### 5.5.1 Configuration of bank register

Figure 5-5 shows the configuration of the bank register.

As shown in the figure, the bank register consists of 4 bits at address 79H (BANK) of the system register. Actually, however, this register is a 2-bit register because the high-order 2 bits are always fixed to "0".

Address 79H Name Bank register (BANK) Symbol **BANK** Bit bз  $b_2$ b<sub>1</sub>  $b_0$ Data î 0 M 0 S S В В Power-ON 0 On reset Clock stop 0 CE 0

Figure 5-5. Configuration of Bank Register

# 5.5.2 Function of bank register

The bank register specifies a bank of the data memory.

Table 5-1 shows the relation between the value of the bank register and a bank of the data memory specified by each value of the bank register.

Because the bank register exists on the system register, its contents can be rewritten no matter which bank may be currently specified.

In other words, the bank register can be manipulated independently of the current status of the bank.

Bank register Data memory (BANK) bank bз  $b_2$ b<sub>1</sub>  $b_0$ 0 0 0 0 BANK0 BANK1 0 0 0 i 1 0 0 1 0 BANK2 BANK3<sup>Note</sup> 0 0 1 1

Table 5-1. Specifying Bank of Data Memory

**Note** BANK3 is not provided on the  $\mu$ PD17016. Do not set this bank with the  $\mu$ PD17016.



## 5.6 Index Register (IX) and Data Memory Row Address Pointer (MP: Memory Pointer)

#### 5.6.1 Configuration of index register and data memory row address pointer

Figure 5-6 shows the configuration of the index register and data memory row address pointer.

As shown in the figure, the index register consists of an index register (IX) and an index enable flag (IXE). IX is a 11-bit register consisting of the low-order 3 bits (IXH) of system register address 7AH, and addresses 7BH and 7CH (IXM and IXL). IXE is the least significant bit of address 7FH (PSW).

The data memory row address pointer (memory pointer) consists of a data memory row address pointer, which consists of 7 bits with the low-order 3 bits of address 7AH (MPH) and address 7BH (MPL), and a data memory row address pointer enable flag (memory pointer enable flag: MPE), which is the most significant bit of address 7AH (MPH).

In other words, the high-order 7 bits of the index register are shared with the data memory row address pointer. Note, however, that the high-order 2 bits of the index register and data memory row address pointer (bits b<sub>2</sub> and b<sub>1</sub> of address 7AH) are always fixed to "0".

7BH 7CH Address 7AH 7EH 7FH Program status word Name Index register (IX) (PSWORD) Memory pointer (MP) IXL **PSW** IXH Symbol IXM MPH MPL  $b_0$ рз  $b_2$ b<sub>1</sub>  $b_0$ bз  $b_2$ b<sub>1</sub> bз  $b_2$ b<sub>1</sub>  $b_0$ рз  $b_2$ b<sub>1</sub>  $b_0$ Bit bз b<sub>2</sub> b<sub>1</sub> bo Data î M 0 0 M ı S S S Χ Ε В В В IX L S В MP Power-ON 0 0 0 0 Clock stop 0 0 0 0 CE 0 0 0 0

Figure 5-6. Configuration of Index Register and Data Memory Row Address Pointer

#### 5.6.2 Functions of index register and data memory row address pointer

The index register and data memory row address pointer modify the addresses of the data memory.

The following paragraphs (1) and (2) explains the functions of the index register and data memory row address pointer, respectively.

A dedicated instruction ("INC IX") that can increment the value of the address register by one is also available. For details on address modification, refer to **7. ALU (Arithmetic Logic Unit) BLOCK**.

#### (1) Index register

The index register modifies a specified data memory address according to the contents of the index register when a data memory manipulation instruction is executed.

This modification, however, is valid only when the IXE flag is set to "1".

To modify an address, the bank, row address, and column address of the data memory are ORed with the contents of the index register, and the instruction is executed to the data memory whose address (called an actual address) is specified by the result of this OR operation.

All the data memory manipulation instructions are subject to address modification by the index register. The following instructions are not subject to modification by the index register.

| INC  | AR       | RORC r    |
|------|----------|-----------|
| INC  | IX       | CALL addr |
| MOVT | DBF, @AR | CALL @AR  |
| PUSH | AR       | RET       |
| POP  | AR       | RETSK     |
| PEEK | WR, rf   | RETI      |
| POKE | rf, WR   | EI        |
| GET  | DBF, p   | DI        |
| PUT  | p, DBF   | STOP s    |
| BR   | addr     | HALT h    |
| BR   | @AR      | NOP       |

## (2) Data memory row address pointer

The data memory row address pointer modifies the address at the indirect transfer destination when a general register indirect transfer instruction ("MOV @r, m" or "MOV m, @r") is executed.

However, this modification is valid only when the MPE flag is set to "1".

To modify the address, the bank and row address at the transfer destination are replaced with the contents of the data memory row address pointer.

Instructions other than the general register indirect transfer instructions are not subject to address modification.

# (3) Index register increment instruction ("INC IX")

This instruction increments the contents of the index register by one.

Because the index register is configured of 9 bits, the contents of the index register are cleared to "000H" if the "INC IX" instruction is executed when the contents of the index register are "1FFH".



# 5.7 General Register Pointer (RP)

# 5.7.1 Configuration of general register pointer

Figure 5-7 shows the configuration of the general register pointer.

As shown in this figure, the general register pointer consists of 7 bits: 4 bits of address 7DH (RPH) of the system register and the high-order 3 bits of address 7EH (RPL). However, because the high-order 3 bits of address 7E are always fixed to 0, actually the low-order 4 bits of this register (the lowest 1 bit of address 7DH and the high-order 3 bits of address 7EH) are valid.

Figure 5-7. Configuration of General Register Pointer

|          | Address    |                          | 70             | Н              |                |    | 7E             | ΞH             |                |  |  |  |
|----------|------------|--------------------------|----------------|----------------|----------------|----|----------------|----------------|----------------|--|--|--|
|          | Name       | General register pointer |                |                |                |    |                |                |                |  |  |  |
|          |            |                          | (RP)           |                |                |    |                |                |                |  |  |  |
|          | Symbol     |                          | RF             | РΗ             |                |    | RI             | PL             |                |  |  |  |
|          | Bit        | bз                       | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> |  |  |  |
|          | Data       | 0                        | 0              | 0              | M              |    |                | î              | В              |  |  |  |
|          |            |                          |                | !<br>!<br>!    | s              |    |                | S              | С              |  |  |  |
|          |            |                          |                | <br>           | B              |    |                | B              | D              |  |  |  |
|          |            |                          |                |                | <br>           |    |                | -              |                |  |  |  |
|          |            |                          |                | !<br>!         | <br>           |    |                |                |                |  |  |  |
| et       | Power-ON   |                          | (              | )              |                |    | (              | )              |                |  |  |  |
| On reset | Clock stop |                          | (              | )              |                |    | (              | )              |                |  |  |  |
| Ŏ        | CE         | 0 0                      |                |                |                |    |                |                |                |  |  |  |

#### 5.7.2 Function of general register pointer

The general register pointer specifies a general register on the data memory.

Figure 5-8 shows the address of the general register specified by the general register pointer.

As shown in the figure, the high-order 4 bits of the general register pointer (RPH: address 7DH) specify a bank, and the low-order 3 bits (RPL: address 7EH) specify a row address.

Because the valid number of bits of the general register pointer is 4, the row addresses (0H through 7H) of BANK0 and BANK1 can be specified as general registers.

For the details on the operations of the general registers, refer to 6. GENERAL REGISTER (GR).

General register pointer (RP) **RPH RPL**  $b_2$ b<sub>1</sub> bo bз  $b_2$ b<sub>1</sub>  $b_0$ î M 0 0 0 В S С S В <u>B</u> ¦ D Specifies row address of each bank Specifies bank Row address Bank 0 0 0 0 0 : 0 0 0 0 1 1H BANK0 0 1 0 2H 0 0 1 1 3Н  $\stackrel{\cdot}{\approx}$ 1 1 0 0 4H BANK1 5H 1 0 1 1 0 6H 1 7H 1 1 1 ¦

Figure 5-8. Address of General Register Specified by General Register Pointer

Caution Because the valid number of bits of the general register pointer is 4, BANK2 and BANK3 cannot be specified.

# 5.7.3 Notes on using general register pointer

The least significant bit of address 7EH (RPL) to which the general register pointer is allocated is used as the BCD flag of the program status word.

When rewriting the value of RPL, therefore, pay attention to the value of the BCD flag.



# 5.8 Program Status Word (PSWORD)

# 5.8.1 Configuration of program status word

Figure 5-9 shows the configuration of the program status word.

As shown in the figure, the program status word consists of 5 bits: the least significant bit of address 7EH (RPL) of the system register and the 4 bits of the address 7FH (PSW).

The program status word consists of five flags, each of which functions independently: BCD (BCD), compare (CMP), carry (CY), zero (Z), and index enable (IXE) flags.

Figure 5-9. Configuration of Program Status Word

|          | Address    |    | 7E             | H              |             |      | 7E             | ΞH             |     |  |  |
|----------|------------|----|----------------|----------------|-------------|------|----------------|----------------|-----|--|--|
|          | Name       |    | (RP)           |                | Pro         | gram | statı          | us wo          | ord |  |  |
|          |            |    |                |                | (PS         | WOF  | RD)            |                |     |  |  |
|          | Symbol     |    | RI             | PL             |             |      | PS             | SW             |     |  |  |
|          | Bit        | Ьз | b <sub>2</sub> | b <sub>1</sub> | bo          | bз   | b <sub>2</sub> | b <sub>1</sub> | bo  |  |  |
|          | Data       |    |                |                | В           | С    | С              | Z              | _   |  |  |
|          |            |    |                | :<br> <br>     | С           | М    | Υ              |                | Х   |  |  |
|          |            |    |                | <br>           | D           | Р    |                |                | E   |  |  |
|          |            |    |                | <br>           | !<br>!      |      |                |                | 1   |  |  |
|          |            |    |                | !<br>!<br>!    | !<br>!<br>! |      |                |                |     |  |  |
|          |            |    |                |                | i<br>!<br>! |      |                |                |     |  |  |
| et       | Power-ON   |    | (              | )              |             |      | (              | )              | ·   |  |  |
| On reset | Clock stop |    | (              | )              |             | 0    |                |                |     |  |  |
| Õ        | CE         |    | (              | )              |             | 0    |                |                |     |  |  |

#### 5.8.2 Function of program status word

The program status word is a register that sets the condition of an operation or transfer instruction of the ALU (Arithmetic Logic Unit) or indicates the result of an operation executed.

Table 5-2 outlines the function of each flag of the program status word.

For details, refer to 7. ALU (Arithmetic Logic Unit) BLOCK.

Table 5-2. Functional Outline of Program Status Word



#### 5.8.3 Notes on using program status word

If an arithmetic operation (addition or subtraction) instruction is executed to the program status word, the "result" of the arithmetic operation is stored to the program status word.

For example, even if an operation that causes a carry to occur is executed, if the result of the operation is 0000B, 0000B is stored to PSW.

#### 5.9 Notes on Using System Register

The data of the system register fixed to "0" is not affected even if a write instruction is executed to it. This data is always "0" when it is read.



## 6. GENERAL REGISTER (GR)

# 6.1 Outline of General Register

Figure 6-1 outlines the general register.

As shown in the figure, the general register consists of a general register pointer and general register body.

The bank and row address of the general register body are specified by the general register pointer.

The general register body is used to transfer data and execute operation between data memory addresses.

Figure 6-1. Outline of General Register



**Note** BANK3 is not provided to the  $\mu$ PD17016.

Caution Because the valid number of bits of the general register pointer is 4, BANK2 and BANK3 cannot be specified.

## 6.2 General Register Body

The general register body consists of 16 nibbles (16 x 4 bits) at the same row addresses on the data memory. For the range of the banks and row addresses that can be specified by the general register pointer and general register, refer to **5.7 General Register Pointer (RP)**.

The 16 nibbles of the same row address specified as a general register executes operation and transfers data with the data memory with a single instruction.

In other words, operation or transfer between data memory addresses can be executed with a single instruction.

The general register can be controlled by a data memory manipulation instruction like the other data memory areas.



#### 6.3 Address Generation of General Register by Instructions

The following subsections 6.3.1 and 6.3.2 explains how the addresses of the general register are generated when each instruction is executed.

For the details of the operation of each instruction, refer to 7. ALU (Arithmetic Logic Unit) BLOCK.

```
6.3.1 Addition ("ADD r, m", "ADDC r, m"),
subtraction ("SUB r, m", "SUBC r, m"),
logical operation ("AND r, m", "OR r, m", "XOR r, m"),
direct transfer ("LD r, m", "ST m, r"),
and rotation processing ("RORC r") instructions
```

Table 6-1 shows the address of general register "R" specified by operand "r" of an instruction. Only specify a column address as operand "r".

Bank Row address Column address

b\_3 b\_2 b\_1 b\_0 b\_2 b\_1 b\_0 b\_3 b\_2 b\_1 b\_0

Contents of general register address

R register pointer r

Table 6-1. Address Generation of General Register

# 6.3.2 Indirect transfer ("MOV @r,m", "MOV m, @r") instructions

Table 6-2 shows the address of the general register "R" specified by operand "r" of an instruction and an indirect transfer address specified by "@R".

|                              |    | Ва             | ınk            |                | Row            | / add          | ress           | Col | umn            | addr           | ess            |
|------------------------------|----|----------------|----------------|----------------|----------------|----------------|----------------|-----|----------------|----------------|----------------|
|                              | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | bз  | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> |
| General register address     |    |                |                |                | gene           |                |                | 4   | -              | r              | -              |
| Indirect transfer address @F | •  | Sam            | ne as          | data           | n mer          | nory           | <b>-</b>       | Co  | onter          | nts of         | R              |

Table 6-2. Address Generation of General Register



# 6.4 Notes on Using General Register

# 6.4.1 Row address of general register

Note that because the row address of the general register is specified by the general register pointer, the bank currently specified may differ from the bank of the general register.

# 6.4.2 Operation between general register and immediate data

No instruction that executes an operation between the general register and immediate data is provided.

To execute an operation between the general register and immediate data, the general register must be treated as a data memory area.

# 7. ALU (Arithmetic Logic Unit) BLOCK

# 7.1 Outline of ALU Block

Figure 7-1 outlines the ALU block.

As shown in the figure, the ALU block consists of an ALU, temporary registers A and B, program status word, decimal adjustment circuit, and data memory address control circuit.

The ALU operates, judges, compares, rotates, and transfers 4-bit data on the data memory.

Data bus Address Temporary Temporary Program status word register A register B control Carry/borrow/ Index modification zero detection/decimal/ memory pointer storage specification Arithmetic operation Logical operation • Bit judgment Comparison Rotation processing Transfer Data memory Decimal adjustment

Figure 7-1. Outline of ALU Block



## 7.2 Configuration and Function of Each Block

#### 7.2.1 ALU

The ALU executes arithmetic or logical operation, bit judgment, comparison, rotation processing, and transfer of 4-bit data according to an instruction specified by the program.

# 7.2.2 Temporary registers A and B

Temporary registers A and B temporarily store 4-bit data.

These registers are automatically used when an instruction is executed and are not controlled by the program.

#### 7.2.3 Program status word

The program status word controls the operation of the ALU and stores the status of the ALU.

For the details on the program status word, refer to 5.8 Program Status Word (PSWORD).

### 7.2.4 Decimal adjustment circuit

If the BCD flag of the program status word is set to "1" as a result of an arithmetic operation executed, the arithmetic operation result is converted into a decimal number by the decimal adjustment circuit.

#### 7.2.5 Address control circuit

The address control circuit specifies an address of the data memory.

At this time, address modification by the index register and data memory row address pointer is also controlled.

# 7.3 ALU Processing Instruction List

Table 7-1 lists the ALU operations when each instruction is executed.

Table 7-2 shows modification of data memory addresses by the index register and data memory row address pointer.

Table 7-3 shows the decimal adjustment data when a decimal operation is executed.



Table 7-1. List of ALU Processing Instruction Operations

| A1.11     | la sta |        |                   | D:#*                 | ! 0                  | D                       | \\\\\.\.\.\.\.\.\.\.           | A -1-1 A /   |                |
|-----------|--------|--------|-------------------|----------------------|----------------------|-------------------------|--------------------------------|--------------|----------------|
| ALU       | Instr  | uction |                   | I                    | ce in Operation du   | ie to Program Stat      | Address IV                     | lodification |                |
| Function  |        |        | Value of BCD flag | Value of<br>CMP flag | Arithmetic operation | Operation of<br>CY flag | Operation of Z flag            | Index        | Memory pointer |
| Addition  | ADD    | r, m   | 0                 | 0                    | Stores result of     | Set if carry or         | Set if result of operation     | Executed     | Not            |
|           |        | m, #n4 |                   |                      | binary operation.    | borrow occurs;          | is 0000B; otherwise, reset.    |              | executed       |
|           | ADDC   | r, m   | 0                 | 1                    | Does not store       | otherwise, reset.       | Holds status if result of      |              |                |
|           |        | m, #n4 |                   |                      | result of binary     |                         | operation is 0000B;            |              |                |
|           |        |        |                   | !<br>!               | operation.           |                         | otherwise, reset.              |              |                |
| Subtrac-  | SUB    | r, m   | 1                 | 0                    | Stores result of     |                         | Set if result of operation is  |              |                |
| tion      |        | m, #n4 |                   |                      | decimal operation.   |                         | 0000B; otherwise, reset.       |              |                |
|           | SUBC   | r, m   | 1                 | 1                    | Does not store       |                         | Holds status if result of      |              |                |
|           |        | m, #n4 |                   |                      | result of decimal    |                         | operation is 0000B; otherwise, |              |                |
|           |        |        |                   |                      | operation.           |                         | reset.                         |              |                |
| Logical   | OR     | r, m   | Any               | Any                  | Not affected         | Holds previous          | Holds previous status.         | Executed     | Not            |
| operation |        | m, #n4 | (held)            | (held)               |                      | status.                 |                                |              | executed       |
|           | AND    | r, m   |                   |                      |                      |                         |                                |              |                |
|           |        | m, #n4 |                   |                      |                      |                         |                                |              |                |
|           | XOR    | r, m   |                   |                      |                      |                         |                                |              |                |
|           |        | m, #n4 |                   |                      |                      |                         |                                |              |                |
| Judgment  | SKT    | m, #n  | Any               | Any                  | Not affected         | Holds previous          | Holds previous status.         | Executed     | Not            |
|           | SKF    | m, #n  | (held)            | (reset)              |                      | status.                 |                                |              | executed       |
| Compare   | SKE    | m, #n4 | Any               | Any                  | Not affected         | Holds previous          | Holds previous status.         | Executed     | Not            |
|           | SKNE   | m, #n4 | (held)            | (held)               |                      | status.                 |                                |              | executed       |
|           | SKGE   | m, #n4 |                   |                      |                      |                         |                                |              |                |
|           | SKLT   | m, #n4 |                   |                      |                      |                         |                                |              |                |
| Transfer  | LD     | r, m   | Any               | Any                  | Not affected         | Holds previous          | Holds previous status          | Executed     | Not            |
|           | ST     | m, r   | (held)            | (held)               |                      | status                  |                                |              | executed       |
|           | MOV    | m, #n4 |                   |                      |                      |                         |                                |              |                |
|           |        | @r, m  |                   |                      |                      |                         |                                |              | Executed       |
|           |        | m, @r  |                   | <br>                 |                      |                         |                                |              |                |
| Rotation  | RORC   | r      | Any               | Any                  | Not affected         | Value of general        | Holds previous value           | Not          | Not            |
|           |        |        | (held)            | (held)               |                      | register bo             |                                | executed     | executed       |



Table 7-2. Modification of Data Memory Address and Modification of Indirect Transfer Address by Index Register and Data Memory Row Address Pointer

| IXE | MPE | Ge | ner            | al re          | egis           | ter            | addı           | ress           | spe                   | ecifi          | ed b           | y r            | Da | ata ı          | mer            | nory           | / ac           | ldre           | ss s           | pec         | cified         | d by           | m              | Indirect transfer address specified |                |                |                |                |                |                |              | ified          | by @r                         |
|-----|-----|----|----------------|----------------|----------------|----------------|----------------|----------------|-----------------------|----------------|----------------|----------------|----|----------------|----------------|----------------|----------------|----------------|----------------|-------------|----------------|----------------|----------------|-------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|----------------|-------------------------------|
|     |     |    | Ba             | ank            |                | <br>           | Row            | V              |                       | Col            | umn            |                |    | Ba             | ank            |                | <br>           | Rov            | V              | !<br>!<br>! | Col            | umn            |                |                                     | Bank           |                |                | 1              | Rov            | V              | 1            | Col            | umn                           |
|     |     |    |                |                |                | a              | ddre           | ss             |                       | add            | ress           | ;              |    |                |                |                | ad             | ddre           | ss             | <br>        | add            | ress           |                |                                     |                |                |                | a              | ddre           | ss             |              | add            | ress                          |
|     |     | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | Ьз                    | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | bз          | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | Ьз                                  | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | Ьз           | b <sub>2</sub> | b <sub>1</sub> b <sub>0</sub> |
| 0   | 0   |    |                |                |                | i<br>i<br>i    |                |                | 1                     |                |                |                |    |                |                |                | <br>           |                |                | !<br>!<br>! |                |                |                |                                     |                |                |                | 1              |                |                | 1            |                |                               |
|     |     | _  |                |                | RP             |                |                | _              | <br> -<br> -          | ı              | r              |                | -  | ВА             | NK             |                | -              |                |                | m           |                |                |                | _                                   | ВА             | NK             | _              | !<br>!         | mR             | _              | !<br>!<br>!  | (              | r) 🛌                          |
|     |     |    |                |                |                |                |                |                |                       |                |                |                |    |                |                |                | <u> </u>       |                |                | -           |                |                |                |                                     |                |                |                | -              |                |                | -            |                |                               |
| 0   | 1   |    |                |                |                | 1              |                |                | <br>                  |                |                |                |    |                |                |                | <br>           |                |                | <br>        |                |                |                |                                     |                |                |                | 1              |                |                | 1            |                |                               |
|     |     |    |                |                |                |                | ditto          | )              | 1<br>1<br>1<br>1<br>1 |                |                |                |    |                |                |                | <br>           | ditto          | )              | <br>        |                |                |                | -                                   |                |                | MP             | <br>           |                | -              | <del> </del> | (              | r) <u>-</u>                   |
| 1   | 0   |    |                |                |                |                |                |                | 1                     |                |                |                |    | ВА             | NK             |                |                |                |                | m           |                |                | _              |                                     | ВА             | NK             |                | -              | mR             |                | 1            |                |                               |
|     |     |    |                |                |                |                | ditto          | )              |                       |                |                |                | -  |                |                | Log            | jica           | IX             | (              | OR<br>-     |                |                | _              | •                                   |                |                |                | gica<br>XM     |                | _              | OR           |                | r)                            |
| 1   | 1   |    |                |                |                |                |                |                | 1<br>1<br>1<br>1      |                |                |                |    |                |                |                | <br>           |                |                | <br>        |                |                |                |                                     |                |                |                | <br>           |                |                | <br>         |                |                               |
|     |     |    |                |                |                |                | ditto          | )              | i<br>I<br>I<br>I      |                |                |                |    |                |                |                | <br>           | ditto          | )              | <br>        |                |                |                | -                                   |                |                | MP             | 1              |                | -              | <br> -<br> - | (              | r) <u>-</u>                   |
|     |     |    |                |                |                | i<br>!         |                |                |                       |                |                |                |    |                |                |                |                |                |                | !<br>!      |                |                |                |                                     |                |                |                | į              |                |                | į            |                |                               |

BANK : bank register
IX : index register
IXE : index enable flag

IXH : bits 10 through 8 of index register
IXM : bits 7 through 4 of index register
IXL : bits 3 through 0 of index register

m : data memory address indicated by mR, mc mR : data memory row address (high-order) mc : data memory column address (low-order)

MP : data memory row address pointer

MPE : memory pointer enable flag
: general register column address

RP : general register pointer
(x) : contents addressed by x
x : direct address such as m and r

Table 7-3. Decimal Adjustment Data

| Operation Result | Hexade | ecimal Addition  | Deci | mal Addition     |
|------------------|--------|------------------|------|------------------|
|                  | CY     | Operation Result | CY   | Operation Result |
| 0                | 0      | 0000B            | 0    | 0000B            |
| 1                | 0      | 0001B            | 0    | 0001B            |
| 2                | 0      | 0010B            | 0    | 0010B            |
| 3                | 0      | 0011B            | 0    | 0011B            |
| 4                | 0      | 0100B            | 0    | 0100B            |
| 5                | 0      | 0101B            | 0    | 0101B            |
| 6                | 0      | 0110B            | 0    | 0110B            |
| 7                | 0      | 0111B            | 0    | 0111B            |
| 8                | 0      | 1000B            | 0    | 1000B            |
| 9                | 0      | 1001B            | 0    | 1001B            |
| 10               | 0      | 1010B            | 1    | 0000B            |
| 11               | 0      | 1011B            | 1    | 0001B            |
| 12               | 0      | 1100B            | 1    | 0010B            |
| 13               | 0      | 1101B            | 1    | 0011B            |
| 14               | 0      | 1110B            | 1    | 0100B            |
| 15               | 0      | 1111B            | 1    | 0101B            |
| 16               | 1      | 0000B            | 1    | 0110B            |
| 17               | 1      | 0001B            | 1    | 0111B            |
| 18               | 1      | 0010B            | 1    | 1000B            |
| 19               | 1      | 0011B            | 1    | 1001B            |
| 20               | 1      | 0100B            | 1    | 1110B            |
| 21               | 1      | 0101B            | 1    | 1111B            |
| 22               | 1      | 0110B            | 1    | 1100B            |
| 23               | 1      | 0111B            | 1    | 1101B            |
| 24               | 1      | 1000B            | 1    | 1110B            |
| 25               | 1      | 1001B            | 1    | 1111B            |
| 26               | 1      | 1010B            | 1    | 1100B            |
| 27               | 1      | 1011B            | 1    | 1101B            |
| 28               | 1      | 1100B            | 1    | 1010B            |
| 29               | 1      | 1101B            | 1    | 1011B            |
| 30               | 1      | 1110B            | 1    | 1100B            |
| 31               | 1      | 1111B            | 1    | 1101B            |

| Operation Result | Hexadecimal Subtraction |                  | Decimal Subtraction |                  |  |  |
|------------------|-------------------------|------------------|---------------------|------------------|--|--|
|                  | CY                      | Operation Result | CY                  | Operation Result |  |  |
| 0                | 0                       | 0000B            | 0                   | 0000B            |  |  |
| 1                | 0                       | 0001B            | 0                   | 0001B            |  |  |
| 2                | 0                       | 0010B            | 0                   | 0010B            |  |  |
| 3                | 0                       | 0011B            | 0                   | 0011B            |  |  |
| 4                | 0                       | 0100B            | 0                   | 0100B            |  |  |
| 5                | 0                       | 0101B            | 0                   | 0101B            |  |  |
| 6                | 0                       | 0110B            | 0                   | 0110B            |  |  |
| 7                | 0                       | 0111B            | 0                   | 0111B            |  |  |
| 8                | 0                       | 1000B            | 0                   | 1000B            |  |  |
| 9                | 0                       | 1001B            | 0                   | 1001B            |  |  |
| 10               | 0                       | 1010B            | 1                   | 1100B            |  |  |
| 11               | 0                       | 1011B            | 1                   | 1101B            |  |  |
| 12               | 0                       | 1100B            | 1                   | 1110B            |  |  |
| 13               | 0                       | 1101B            | 1                   | 1111B            |  |  |
| 14               | 0                       | 1110B            | 1                   | 1100B            |  |  |
| 15               | 0                       | 1111B            | 1                   | 1101B            |  |  |
| -16              | 1                       | 0000B            | 1                   | 1110B            |  |  |
| -15              | 1                       | 0001B            | 1                   | 1111B            |  |  |
| -14              | 1                       | 0010B            | 1                   | 1100B            |  |  |
| -13              | 1                       | 0011B            | 1                   | 1101B            |  |  |
| -12              | 1                       | 0100B            | 1                   | 1110B            |  |  |
| -11              | 1                       | 0101B            | 1                   | 1111B            |  |  |
| -10              | 1                       | 0110B            | 1                   | 0000B            |  |  |
| -9               | 1                       | 0111B            | 1                   | 0001B            |  |  |
| -8               | 1                       | 1000B            | 1                   | 0010B            |  |  |
| -7               | 1                       | 1001B            | 1                   | 0011B            |  |  |
| -6               | 1                       | 1010B            | 1                   | 0100B            |  |  |
| -5               | 1                       | 1011B            | 1                   | 0101B            |  |  |
| -4               | 1                       | 1100B            | 1                   | 0110B            |  |  |
| -3               | 1                       | 1101B            | 1                   | 0111B            |  |  |
| -2               | 1                       | 1110B            | 1                   | 1000B            |  |  |
| -1               | 1                       | 1111B            | 1                   | 1001B            |  |  |

**Remark** The operation results in the shaded portion are not correctly adjusted by the decimal adjustment circuit.



## 7.4 Notes on Using ALU

## 7.4.1 Notes on using operation to program status word

If an arithmetic operation is executed on the program status word, the result of the arithmetic operation is stored in the program status word.

The CY and Z flags of the program status word are set or reset depending on the result of the arithmetic operation. If an arithmetic operation is executed on the program status word itself, the result of the operation is stored in the program status word, which makes it impossible to judge occurrence of a carry or a borrow, or whether the result of the operation is zero.

If the CMP flag is set, however, the result of the operation is not stored in the program status word, so that the CY and Z flags are set or reset normally.

# 7.4.2 Notes on using decimal operation

A decimal operation can be executed only if the result falls within the following range:

(1) Result of addition : 0 to 19 in decimal

(2) Result of subtraction: 0 to 9 or -10 to -1 in decimal

If a decimal operation is executed exceeding this range, the CY flag is set, and the result is a value greater than 1010B (0AH).

# 8. REGISTER FILE (RF)

# 8.1 Outline of Register File

Figure 8-1 outlines the register file.

As shown in the figure, the register file consists of control registers existing on a space different from that of the data memory, and a portion overlapping the data memory.

The control registers set the conditions of the peripheral hardware units.

Data are read from or written to the register file via the window register.

Register file 0 Peripheral hardware Control registers 1 (separate space from data memory) 2 Row address 3 4 (Space same as data memory) Data is manipulated via window register 5 6 7 System register Window register

Figure 8-1. Outline of Register File



## 8.2 Configuration and Function of Register File

Figure 8-2 shows the configuration of and relation with the data memory of the register file.

Addresses are allocated to the register file in 4-bit units, like the data memory, and the register file has a total of 128 nibbles with row addresses 0H through 7H and column addresses 0H through 0FH.

Control registers that set the conditions of the peripheral hardware units are allocated to addresses 00H through 3FH.

Addresses 40H through 7FH overlap the data memory.

To put it another way, the addresses 40H through 7FH of the register file are the memory addresses of the bank currently selected of the data memory.

These addresses, 40H through 7FH, can be treated in the same manner as the normal data memory areas, except that they can be manipulated by a register file manipulation instruction ("PEEK WR, rf" or "POKE rf, WR"), because they overlap the data memory.



Figure 8-2. Configuration of Register File and Its Relation with Data Memory

**Note** BANK3 is not provided to the  $\mu$ PD17016.

#### 8.2.1 Register file manipulation instructions ("PEEK WR, rf" and "POKE rf, WR")

Data are read from or written to the register file via the window register in the system register by using a register file manipulation instruction ("PEEK WR, rf" or "POKE rf, WR"). The operation of each instruction is explained below.

#### (1) "PEEK WR, rf"

This instruction reads the data of the register file addressed by "rf" to the window register.

# (2) "POKE rf, WR"

This instruction writes the data of the window register to the register file addressed by "rf".

# 8.3 Control Registers

Figure 8-3 shows the configuration of the control registers.

As shown in this figure, a total of 64 nibbles (64 words  $\times$  4 bits) at addresses 00H through 3FH of the register file can be used as control registers.

Of these nibbles, however, 19 nibbles are actually used. The remaining 45 nibbles are unused registers that are prohibited from being read or written.

Each control register has an attribute of 1 nibble, and is classified into four types: read/write (R/W), read-only (R), write-only (W), and read-and-reset (R & Reset).

Nothing is changed even if data is written to a read-only (R and R & Reset) register.

An "undefined" value is read if a write-only (W) register is read.

Of the 4-bit data in 1 nibble, the bit fixed to "0" is always "0" when it is read or written.

The 45 nibbles of unused registers are undefined when they are read, and nothing is changed when data is written to them.



Figure 8-3. Configuration of Control Registers (1/2)

| Colum    | address             |                       |                                                     |                                         |                    |                                         |                                                         |                              |                                         |
|----------|---------------------|-----------------------|-----------------------------------------------------|-----------------------------------------|--------------------|-----------------------------------------|---------------------------------------------------------|------------------------------|-----------------------------------------|
| Row      | s Item              | 0                     | 1                                                   | 2                                       | 3                  | 4                                       | 5                                                       | 6                            | 7                                       |
| 0<br>(8) | Name                |                       | Stack<br>pointer<br>(SP)                            | Serial<br>I/O mode<br>select            |                    | I/F count<br>gate<br>judge              | PLL unlock<br>FF judge                                  | A/D converter compare judge  | CE pin<br>level<br>judge                |
|          | Symbol              |                       | (SSSPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPPP              | S S S S O O O O O O O O O O O O O O O O |                    | 0 0 0 FCGOSTT                           | 0 0 0 P<br>L<br>U<br>L                                  | O O O                        | 0 0 0 CE                                |
|          | Read/<br>Write      |                       | R/W                                                 | R/W                                     |                    | R                                       | R & Reset                                               | R                            | R                                       |
| 1 (9)    | Name                | LCD<br>mode<br>select |                                                     | IF counter<br>mode<br>select            |                    | A/D converter<br>channel<br>select      |                                                         | Key<br>input<br>judge        | Timer carry<br>FF judge                 |
|          | Symbol  Read/ Write | 0 0 K LCDD R/W        |                                                     | F F F F C C C C M M C C C K M D D K K 0 |                    | A A A A A D D D D D D D D D D D D D D D |                                                         | 0 0 0 K<br>E<br>Y<br>J       | 0 0 0 B<br>T<br>M<br>0 C<br>Y           |
| 2<br>(A) | Name                |                       | PLL mode select                                     |                                         | IF counter control |                                         |                                                         |                              | Port 0C<br>group<br>I/O select          |
|          | Symbol              |                       | P P P P L L L L L M M M M D D D D D 3 2 1 0         |                                         | O O FCSTRT         |                                         |                                                         |                              | 0 0 0 POCG-O                            |
|          | Read/<br>Write      |                       | R/W                                                 |                                         | W                  |                                         |                                                         |                              | R/W                                     |
| 3<br>(B) | Name                |                       | PLL reference<br>mode select                        |                                         |                    |                                         | Port 1A<br>bit I/O<br>select                            | Port 0B<br>bit I/O<br>select | Port 0A<br>bit I/O<br>select            |
|          | Symbol              |                       | P P P L L L L R R R F F F C C C C K K K K K 3 2 1 0 |                                         |                    |                                         | P P P P P 1 1 1 A A A A B B B B B I I I I I I I I I I I | P                            | P P P P O O O O O O O O O O O O O O O O |
|          | Read/<br>Write      |                       | R/W                                                 |                                         |                    |                                         | R/W                                                     | R/W                          | R/W                                     |

Figure 8-3. Configuration of Control Registers (2/2)

|   |                                                     |   |   | Of Control i |   |   |       |
|---|-----------------------------------------------------|---|---|--------------|---|---|-------|
| 8 | 9                                                   | А | В | С            | D | E | F     |
|   | Timer<br>mode<br>select                             |   |   |              |   |   |       |
|   | B B B T T M M M M M 1 1 1 0 0 C C K K K K K 1 0 1 0 |   |   |              |   |   |       |
|   | R/W                                                 |   |   |              |   |   |       |
|   |                                                     |   |   |              |   |   |       |
|   |                                                     |   |   |              |   |   |       |
|   |                                                     |   |   |              |   |   |       |
|   |                                                     |   |   |              |   |   |       |
|   |                                                     |   |   |              |   |   |       |
|   |                                                     |   |   |              |   |   | 1 1 1 |



Table 8-1. Outline of Peripheral Hardware Control Functions of Control Registers (1/3)

| Peripheral                   |                              | Control re | gister         |                                     | Peripheral h                                             | On reset                                                                                                                                                  |             |               |          |
|------------------------------|------------------------------|------------|----------------|-------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------|----------|
| hardware                     | Name                         | Address    | Read/<br>Write | b3 b2 Symbol b1 b0                  | Functional outline                                       | Set value                                                                                                                                                 | Power<br>ON | Clock<br>stop | CE       |
| Stack                        | Stack pointer<br>(SP)        | 01H        | R/W            | (SP3)<br>(SP2)<br>(SP1)<br>(SP0)    | Stack pointer                                            |                                                                                                                                                           | 7           | 7             | 7        |
| Timer                        | Timer mode<br>select         | 09H        | R/W            | BTM1CK1 BTM1CK0 BTM0CK1 BTM0CK0     | Sets timer interrupt time.  Sets time of timer carry FF. | 0 0 1 1<br>100 ms 250 ms 5 ms 1 ms<br>0 1 1 1<br>100 ms 250 ms 5 ms 1 ms<br>0 1 1 1                                                                       | 0           | 0             | Retained |
|                              | Timer carry FF judge         | 17H        | R &<br>Reset   | 0<br>0<br>0<br>BTM0CY               | Detects timer carry FF                                   | 0: FF reset, 1: FF set                                                                                                                                    | 0           | 1             | 1        |
| Pin                          | CE pin level<br>judge        | 07H        | R              | 0<br>0<br>0<br>CE                   | Detects CE pin status                                    | 0: low level, 1: high level                                                                                                                               | _           | _             | _        |
| PLL frequency<br>synthesizer | PLL unlock<br>FF judge       | 05H        | R &<br>Reset   | 0<br>0<br>0<br>PLLUL                | Detects unlock FF status                                 | 0: lock, 1: unlock<br>Read & reset                                                                                                                        | Undefined   | Retained      | Retained |
|                              | PLL mode select              | 21H        | R/W            | PLLMD3 PLLMD2 PLLMD1 PLLMD0         | 0 0 Sets division mode of PLL                            | 0 0 1 1 disable MF VHF HF 0 1 0 1                                                                                                                         | 0           | 0             | Retained |
|                              | PLL reference<br>mode select | 31H        | R/W            | PLLRFCK3 PLLRFCK2 PLLRFCK1 PLLRFCK0 | Sets<br>reference<br>frequency of<br>PLL                 | 0:1.25 kHz 1:2.5 kHz 2:5 kHz 3:10 kHz<br>4:6.25 kHz 5:12.5 kHz 6:25 kHz 7:50 kHz<br>8:3 kHz 9:A:B: setting prohibited<br>C:1 kHz D:9 kHz E:100 kHz F: off | F           | F             | Retained |
| A/D converter                | A/D converter channel select | 14H        | R/W            | ADCCH3 ADCCH2 ADCCH1 ADCCH0         | Selects pin used for A/D converter                       | 0:AD <sub>0</sub> 1:AD <sub>1</sub> 2:AD <sub>2</sub> 3:AD <sub>3</sub><br>4:AD <sub>4</sub> 5:AD <sub>5</sub> 6:7:Input port                             | 7           | 7             | 7        |
|                              | A/D converter compare judge  | 06H        | R              | 0<br>0<br>ADCCMP                    | Detects result of comparison by A/D converter            | 0:Vref>Vadcin<br>1:Vref <vadcin< td=""><td>Undefined</td><td>Retained</td><td>Retained</td></vadcin<>                                                     | Undefined   | Retained      | Retained |

<sup>-:</sup> Determined by the status of the pin.



Table 8-1. Outline of Peripheral Hardware Control Functions of Control Registers (2/3)

| Peripheral   |                    | Control register |         |           |                                                                                 | hardware control function               | On reset |           |           |
|--------------|--------------------|------------------|---------|-----------|---------------------------------------------------------------------------------|-----------------------------------------|----------|-----------|-----------|
| hardware     | Name               | Address          | Read/   | b3        | Functional outline                                                              | Set value                               | Power    | Clock     | CE        |
|              |                    |                  | Write   | b2 Symbol |                                                                                 |                                         | ON       | stop      |           |
|              |                    |                  |         | b1        |                                                                                 |                                         |          |           |           |
|              |                    |                  |         | b0        |                                                                                 |                                         |          |           |           |
| General-     | Port 0C group      | 27H              | R/W     | 0         |                                                                                 |                                         |          |           |           |
| purpose port | I/O select         |                  |         | 0         |                                                                                 |                                         |          |           |           |
|              |                    |                  |         | 0         |                                                                                 |                                         |          |           |           |
|              |                    |                  |         | P0CGIO    | Sets synchronously input/output mode of P0C <sub>3</sub> -P0C <sub>0</sub> pins | 0: Input, 1: Output                     | 0        | 0         | 0         |
|              | Port 1A bit I/O    | 35H              | R/W     | P1ABIO3   | P1A₃ pin \                                                                      |                                         |          |           |           |
|              | select             |                  |         | P1ABIO2   | P1A <sub>2</sub> pin                                                            |                                         |          |           |           |
|              |                    |                  |         | P1ABIO1   | P1A₁ pin                                                                        |                                         |          |           |           |
|              |                    |                  |         | P1ABIO0   | P1A <sub>0</sub> pin Sets                                                       |                                         |          |           |           |
|              | Port 0B bit I/O    | 36H              | R/W     | P0BBIO3   | P0B <sub>3</sub> pin input/                                                     |                                         |          |           |           |
|              | select             |                  |         | P0BBIO2   | P0B <sub>2</sub> pin output                                                     |                                         |          |           |           |
|              |                    |                  |         | P0BBIO1   | P0B <sub>1</sub> pin mode                                                       | 0: Input, 1: Output                     | 0        | 0         | 0         |
|              |                    |                  |         | P0BBIO0   | P0B <sub>0</sub> pin of each                                                    |                                         |          |           |           |
|              | Port 0A bit I/O    | 37H              | R/W     | P0ABIO3   | P0A₃ pin port                                                                   |                                         |          |           |           |
|              | select             |                  |         | P0ABIO2   | P0A <sub>2</sub> pin pin                                                        |                                         |          |           |           |
|              |                    |                  |         | P0ABIO1   | P0A₁ pin                                                                        |                                         |          |           |           |
|              |                    |                  |         | P0ABIO0   | P0A₀ pin                                                                        |                                         |          |           |           |
| Serial       | Serial I/O mode    | 02H              | R/W     | SIO1TS    | Sets start of serial interface.                                                 | 0: Does not operate, 1: Starts          |          |           |           |
| interface    | select             |                  |         | SIO1HIZ   | Sets P0B <sub>1</sub> /SO pin.                                                  | 0: General-purpose port, 1: Serial out  |          |           |           |
|              |                    |                  |         | SIO1CK1   | Sets clock of                                                                   | 0 0 1 1                                 | 0        | 0         | 0         |
|              |                    |                  |         | SIO1CK0   | serial interface.                                                               | External 75 kHz 150 kHz 450 kHz 0 1 0 1 |          |           |           |
| Frequency    | IF counter gate    | 04h              | R       | 0         |                                                                                 |                                         |          |           |           |
| counter      | judge              |                  |         | 0         |                                                                                 |                                         |          |           |           |
|              |                    |                  |         | 0         |                                                                                 |                                         |          |           |           |
|              |                    |                  |         | IFCGOSTT  | Detects opening/                                                                | 0: Close, 1: Open                       | 0        | Undefined | Undefined |
|              |                    |                  |         |           | closing of gate of                                                              |                                         |          |           |           |
|              |                    | 45               | <b></b> | 150145    | frequency counter Selects                                                       | 0 0 4 4                                 |          |           |           |
|              | IF counter mode    | 12H              | R/W     | IFCMD1    | frequency counter/BEEP                                                          | 0 0 1 1 BEEP FMIF AMIF Setting          |          |           |           |
|              | select             |                  |         | IFCMD0    | ✓ mode.                                                                         | 0 1 0 1                                 | 0        | 0         | Retained  |
|              |                    |                  |         | IFCCK1    | Sets gate time of frequency                                                     | 1 ms 4 ms 8 ms Open                     |          |           |           |
|              | IF assert          | 0011             | DAY     | IFCCK0    | J counter.                                                                      | 0 1 1 1                                 |          |           |           |
|              | IF counter control | 23H              | R/W     | 0         |                                                                                 |                                         |          |           |           |
|              |                    |                  |         | 0         | Charifing start of                                                              | O. NOD in atmostic to the Other         |          |           | Date! !   |
|              |                    |                  |         | IFCSTRT   | Specifies start of frequency counter.                                           | 0: NOP instruction, 1: Start            | 0        | 0         | Retained  |
|              |                    |                  |         | IFCRES    | Specifies data                                                                  | 0: NOP instruction, 1: Reset            |          |           |           |
|              |                    |                  |         |           | reset of                                                                        | ,                                       |          |           |           |
|              |                    |                  |         |           | frequency counter.                                                              |                                         |          |           |           |



Table 8-1. Outline of Peripheral Hardware Control Functions of Control Registers (3/3)

| Peripheral | Control register |         |       |        | Peripheral h | nardware control function | On reset              |       |           |           |
|------------|------------------|---------|-------|--------|--------------|---------------------------|-----------------------|-------|-----------|-----------|
| hardware   | Name             | Address | Read/ | b3     |              | Functional outline        | Set value             | Power | Clock     | CE        |
|            |                  |         | Write | b2 Syı | mbol         |                           |                       | ON    | stop      |           |
|            |                  |         |       | b1     |              |                           |                       |       |           |           |
|            |                  |         |       | b0     |              |                           |                       |       |           |           |
| LCD driver | LCD mode select  | 10H     | R/W   | 0      |              |                           |                       |       |           |           |
|            |                  |         |       | 0      |              |                           |                       |       |           |           |
|            |                  |         |       | KSEN   |              | Sets key source           | 0: Key source off,    | 0     | 0         | Retained  |
|            |                  |         |       |        |              | signal output.            | 1: Key source on      |       |           |           |
|            |                  |         |       | LCDEN  | ı            | Sets LCD                  | 0: Display off,       |       |           |           |
|            |                  |         |       |        |              | display output.           | 1: Display on         |       |           |           |
|            | Key input judge  | 16H     | R &   | 0      |              |                           |                       |       |           |           |
|            |                  |         | Reset | 0      |              |                           |                       |       |           |           |
|            |                  |         |       | 0      |              |                           |                       |       |           |           |
|            |                  |         |       | KEYJ   |              | Detects key input         | 0: No latch, 1: Latch | 0     | Undefined | Undefined |
|            |                  |         |       |        |              | latch of LCD key          |                       |       |           |           |
|            |                  |         |       |        |              | source                    |                       |       |           |           |

# 8.4 Notes on Using Register File

Bear in mind the following points (1) through (3) when manipulating the write-only registers (W), read-only registers (R), and unused registers of the control registers (addresses 00H through 3FH of the register file).

- (1) When a write-only register is read, an "undefined value" is read.
- (2) Nothing is changed even if data is written to a read-only register.
- (3) An "undefined value" is read if an unused register is read. Nothing is changed even if data is written to an unused register.

# 9. DATA BUFFER (DBF)

# 9.1 Outline of Data Buffer

Figure 9-1 outlines the data buffer.

The data buffer is located on the data memory and has the following two functions:

- (1) Reads constant data on program memory (table reference)
- (2) Transfers data with peripheral hardware unit

Figure 9-1. Outline of Data Buffer





#### 9.2 Data Buffer

# 9.2.1 Configuration of data buffer

Figure 9-2 shows the configuration of the data buffer.

As shown in the figure, the data buffer consists of a total of 16 bits at addresses 0CH through 0FH of BANK 0 on the data memory.

The 16-bit data consists of bit b<sub>3</sub> at address 0CH as the MSB and bit b<sub>0</sub> at address 0FH as the LSB.

Because the data buffer is located on the data memory, it can be manipulated by all data memory manipulation instructions.

Column address 2 5 7 8 В С D Е 0 Data buffer (DBF) 1 2 Row address 3 4 Data memory 5 BANK0 6 BANK1 BANK2 BANK3<sup>Note</sup> System register **Note** BANK3 is not provided on the  $\mu$ PD17016 0CH 0DH 0ED 0FH Address Data memory Bit bо b3  $b_2 \mid b_1 \mid b_0$ bз b<sub>2</sub> b<sub>1</sub> b<sub>2</sub> b<sub>1</sub> **b**<sub>0</sub> **b**<sub>3</sub> b<sub>2</sub> b<sub>1</sub> b<sub>0</sub> b<sub>3</sub> Bit b<sub>15</sub> b<sub>14</sub> b<sub>13</sub> b<sub>12</sub> b<sub>11</sub> b<sub>10</sub> b<sub>9</sub> b8 b7  $b_6$ b<sub>5</sub> b<sub>4</sub> b<sub>3</sub> b<sub>2</sub> b<sub>1</sub> Signal DBF3 DBF2 DBF1 DBF0 Ĺ M Data buffer Data S S В В Data

Figure 9-2. Configuration of Data Buffer

#### 9.2.2 Table reference instruction ("MOVT DBF, @AR")

This instruction reads the contents of the program memory addressed by the contents of the address register to the data buffer.

One stack level is used when the table reference instruction is used.

With the  $\mu$ PD17017 all the addresses of the program memory can be referenced by this instruction, but with the  $\mu$ PD17016 only the address 0000H through 00FFH can be referenced.

#### 9.2.3 Peripheral hardware control instructions ("PUT", "GET")

The operations of the "PUT" and "GET" instructions are as follows:

#### (1) GET DBF, p

This instruction reads the data of the peripheral register addressed by p to the data buffer.

#### (2) PUT p, DBF

This instruction sets the data of the data buffer to the peripheral register addressed by p.

#### 9.3 Peripheral Hardware and Data Buffer List

Table 9-1 lists the peripheral hardware units and the functions of the data buffer.



Table 9-1. Relations between Peripheral Hardware and Data Buffer (1/2)

| Peripheral hardware           |                           | Peripheral registe          | r that transfers da | ata with data but  | ffer                             |
|-------------------------------|---------------------------|-----------------------------|---------------------|--------------------|----------------------------------|
|                               |                           | Name                        | Symbol              | Peripheral address | Execution of PUT/GET instruction |
| A/D converter                 |                           | A/D converter data register | ADCR                | 02H                | PUT/GET                          |
| Serial interface              | Serial interface 1 (SIO1) | Presettable shift register  | SIO1SFR             | 03H                | PUT/GET                          |
| D/A converter (PWM output)    | PWM₀ pin                  | PWM data register 0         | PWMR0               | 05H                | PUT/GET                          |
|                               | PWM₁ pin                  | PWM data register 1         | PWMR1               | 06H                |                                  |
| Address register              | (AR)                      | Address register            | AR                  | 40H                | PUT/GET                          |
| PLL frequency synthesizer     |                           | PLL data register           | PLLR                | 41H                | PUT/GET                          |
| Key source controller/decoder |                           | Key source data register    | KSR                 | 42H                | PUT/GET                          |
| Frequency count               | er                        | IF counter data register    | IFC                 | 43H                | GET                              |



Table 9-1. Relations between Peripheral Hardware and Data Buffer (2/2)

| Function                          |                              |                                                                                                                                                    |  |  |  |
|-----------------------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Number of I/O bits of data buffer | Number of bits actually used | Outline                                                                                                                                            |  |  |  |
| 8                                 | 6                            | Sets compare voltage V <sub>REF</sub> data of A/D converter $V_{REF} = \frac{x - 0.5}{64} \times V_{DD}$ , $1 \le x \le 63$                        |  |  |  |
| 8                                 | 8                            | Sets serial out data and reads serial in data.                                                                                                     |  |  |  |
| 8                                 | 8                            | Sets duty factor of output signal of D/A converter.<br>$Duty \ D = \frac{x + 0.25}{256} \times 100 \ \%, \ 0 \le x \le 255$ Frequency f = 878.9 Hz |  |  |  |
| 16                                | 13Note                       | Transfers data with address register.                                                                                                              |  |  |  |
| 16                                | 16                           | Sets division ratio (N value) of PLL.                                                                                                              |  |  |  |
| 16                                | 16                           | Sets output data of key source signal.                                                                                                             |  |  |  |
| 16                                | 16                           | Reads count value of frequency counter.                                                                                                            |  |  |  |

**Note** 8 bits in the case of the  $\mu$ PD17016.



# 9.4 Notes on Using Data Buffer

Bear in mind the following points (1) through (3) concerning unused peripheral address and write-only peripheral registers (PUT only) and read-only peripheral registers (GET only) when transferring data with the peripheral hardware units via the data buffer.

- (1) When a write-only register is read, an "undefined value" is read.
- (2) Nothing is changed even if data is written to a read-only register.
- (3) An "undefined value" is read if an unused register is read. Nothing is changed even if data is written to an unused register.

**72** 

#### 10. INTERRUPT

## 10.1 Outline of Interrupt Block

Figure 10-1 outlines the interrupt block.

As shown in the figure, the interrupt block temporarily stops the program currently being executed in response to an interrupt request output from any peripheral hardware unit and branches execution to an interrupt vector address.

The interrupt block consists of an "interrupt control block" for each peripheral hardware unit, "interrupt enable flip-flop" that enables all the interrupts, "stack pointer" that is controlled when an interrupt is acknowledged, "address stack register", "program counter", and "system register stack".

The "interrupt control block" of each peripheral hardware unit consists of an "interrupt request flag (IRQxxx)" that detects each interrupt request, "interrupt permission flag (IPxxx)" that enables each interrupt, and "vector address generator (VAG)" that specifies a vector address when an interrupt is acknowledged.

The peripheral hardware units that have an interrupt function are as follows:

- INTo pin (rising-edge detection)
- Timer

Interrupt control block IPTM flag Program counter Vector address IRQTM flag Timer generator 03H Address stack Stack pointer register IP0 flag System register Vector address IRQ0 flag INT<sub>0</sub> generator 05H pin Interrupt stack register Interrupt enable DI, El instruction flip-flop

Figure 10-1. Outline of Interrupt Block



## 10.2 Interrupt Control Block

The interrupt control block is provided to each peripheral hardware unit and detects an interrupt request, enables the interrupt, and generates a vector address when the interrupt is acknowledged.

#### 10.2.1 Configuration and function of interrupt request flag (IRQxxx)

Each interrupt request flag (IRQxxx) is set to "1" when an interrupt request is issued from the corresponding peripheral hardware unit, and is reset to "0" when the interrupt is acknowledged. It cannot be set by software.

Once this flag has been set to "1", it is not reset until the corresponding interrupt is acknowledged or an interrupt request reset macro is executed.

If more than one interrupt request is issued at the same time, the interrupt request flag corresponding to the interrupt that has not been acknowledged is not reset.

Table 10-1 shows the software macros that reset interrupt requests.

These macros are defined in the device file and can be used by INCLUDEing the files supplied with the device file (D17016.INC for the  $\mu$ PD17016 and D17017.INC for the  $\mu$ PD17017) on the source program.

Table 10-1. Software Macros That Reset Interrupt Requests

| Function                                       | Macro Name |  |  |
|------------------------------------------------|------------|--|--|
| Resets timer interrupt request.                | CLR1_IRQTM |  |  |
| Resets INT <sub>0</sub> pin interrupt request. | CLR1_IRQ0  |  |  |

Caution If the above macros are used, the contents of the window register are destroyed.

If an embedded macro instruction is used immediately before the above macro instructions, an "object error" occurs when the source file is assembled and then loaded to the in-circuit emulator. To use an embedded macro instruction immediately before the above macro instructions, insert a comment statement between them.

Moreover, while either of the above macro instructions is executed, the other interrupt request cannot be acknowledged. For details, refer to 10.11 Notes on Using Interrupt.

74

#### 10.2.2 Configuration and function of interrupt permission flag (IPxxx)

Each interrupt permission flag enables the interrupt of the corresponding peripheral hardware unit. So that an interrupt is acknowledged, all the following three conditions must be satisfied.

- The interrupt must be enabled by the corresponding interrupt permission flag.
- An interrupt request must be issued by the corresponding interrupt request flag.
- The "EI" instruction (that enables all the interrupts) must be executed.

Enabling or disabling an interrupt is controlled by a software macro.

Table 10-2 lists the available software macros.

These macros are defined in the device file and can be used by INCLUDEing the files supplied with the device file (D17016.INC for the  $\mu$ PD17016 and D17017.INC for the  $\mu$ PD17017) on the source program.

Table 10-2. Software Macros Enabling/Disabling Interrupts

| Function                                                | Macro Format      |  |  |
|---------------------------------------------------------|-------------------|--|--|
| Enables timer interrupt                                 | SET1_IPTM         |  |  |
| Enables INT₀ pin interrupt                              | SET1_IP0          |  |  |
| Enables timer interrupt and INTo pin interrupt          | SET2_IPTM_IP0     |  |  |
| Disables timer interrupt                                | CLR1_IPTM         |  |  |
| Disables INT₀ pin interrupt                             | CLR1_IP0          |  |  |
| Disables timer interrupt and INTPo pin interrupt        | CLR2_IPTM_IP0     |  |  |
| Disables timer interrupt and enables INT₀ pin interrupt | INIT_NOT_IPTM_IP0 |  |  |
| Enables timer interrupt and disables INTo pin interrupt | INIT_IPTM_NOT_IP0 |  |  |

#### Caution If the above macros are used, the contents of the window register are destroyed.

If an embedded macro instruction is used immediately before the above macro instructions, an "object error" occurs when the source file is assembled and then loaded to the in-circuit emulator. To use an embedded macro instruction immediately before the above macro instructions, insert a comment statement between them.

The status of the interrupt at reset is as follows:

#### • On power-ON reset

The interrupt is disabled.

## · On execution of clock stop instruction

The interrupt is disabled.

#### On CE reset

The interrupt is disabled.

#### · In halt status

The interrupt permission flag holds the previous status.



## 10.2.3 Vector address generator (VAG)

The vector address generator generates a branch address (vector address) of the program memory for the interrupt source acknowledged if a peripheral hardware interrupt has been acknowledged.

Table 10-3 shows the vector address of each interrupt source.

Table 10-3. Vector Address of Each Interrupt Source

| Interrupt Source | Vector Address |  |  |  |
|------------------|----------------|--|--|--|
| INT₀ pin         | 05H            |  |  |  |
| Timer            | 03H            |  |  |  |

76

## 10.3 Interrupt Stack Register

## 10.3.1 Configuration and function of interrupt stack register

Figure 10-2 shows the configuration of the interrupt stack register and the system register whose contents are saved to the interrupt stack register.

The interrupt stack register saves the contents of the following system registers when an interrupt is acknowledged.

- Bank register (BANK)
- Index enable flag (IXE)

When an interrupt is acknowledged and the contents of the above system registers are saved to the interrupt stack register, the contents of the above system registers are reset to "0".

The interrupt stack register can save up to 4 levels of the contents of the above system registers.

Therefore, up to four levels of multiple interrupts can be executed.

The contents of the interrupt stack register are restored to the system registers when an interrupt return instruction ("RETI") is executed.

Figure 10-2. Configuration of Interrupt Stack Register

| Interrupt stack register (INTSK) |            |                |                |                |    |                |                |                |
|----------------------------------|------------|----------------|----------------|----------------|----|----------------|----------------|----------------|
| Name                             | Bank stack |                |                | Status stack   |    |                |                |                |
| Bit                              | bз         | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> | bз | b <sub>2</sub> | b <sub>1</sub> | b <sub>0</sub> |
| 0H                               | _          | -              |                | 1              | _  | -              | -              |                |
| 1H                               | _          | -              |                | 1              | _  | -              | -              |                |
| 2H                               | _          | <u> </u>       | <br>           | <br>           | _  | -              | -              |                |
| 3H                               | _          | <u> </u>       | <br>           | <br>           | _  | -              | -              | <br>           |

Remark -: Bit not saved

**77** 



## 10.3.2 Interrupt stack register operation

Figure 10-3 illustrates the operation of the interrupt stack register.

If multiple interrupts exceeding 4 levels are acknowledged, the first saved contents are discarded and therefore, must be saved by program.

Figure 10-3. Operation of Interrupt Stack Register

## (a) If interrupt does not exceed level 4



# (b) If interrupt exceeds level 4



## 10.4 Stack pointer, address stack register, and program counter

The address stack register saves the return address to which execution is to be returned from an interrupt processing routine.

The stack pointer specifies the address of the address stack register.

When an interrupt is acknowledged, therefore, the value of the stack pointer is decremented by one and the value of the program counter at that time is saved to the address stack register specified by the stack pointer.

When the dedicated return instruction "RETI" is executed after the processing of the interrupt processing routine has been executed, the contents of the address stack register specified by the stack pointer are restored to the program counter, and the value of the stack pointer is incremented by one.

For further information, also refer to 3. ADDRESS STACK (ASK).

## 10.5 Interrupt Enable Flip-Flop (INTE)

The interrupt enable flip-flop enables all the interrupts.

When this flip-flop is set, all the interrupts are enabled. When it is reset, all the interrupts are disabled.

This flip-flop is set or reset by using dedicated instructions "EI (to set)" and "DI (to reset)".

The "EI" instruction sets this flip-flop when the instruction next to the "EI" instruction is executed, and the "DI" instruction resets the flip-flop while the "DI" instruction is executed.

When an interrupt is acknowledged, this flip-flop is automatically reset.

Nothing is affected even if the "DI" instruction is executed in the DI state, or if the "EI" instruction is executed in the EI state.

This flip-flop is reset on power-ON reset, CE reset, and on execution of the clock stop instruction.



## 10.6 Acknowledging Interrupts

#### 10.6.1 Acknowledging interrupts and priority

An interrupt is acknowledged in the following procedure:

- (1) Each peripheral hardware unit outputs an interrupt request signal to the corresponding interrupt control block if a given interrupt condition is satisfied (e.g., if a rising signal is input to the INT<sub>0</sub> pin).
- (2) When the interrupt control block has received the interrupt request signal from the peripheral hardware unit, it sets the corresponding interrupt request flag (e.g., IRQ0 flag if the peripheral unit is the INT<sub>0</sub> pin) to "1".
- (3) If the interrupt permission flag corresponding to the interrupt request flag (e.g., IP0 flag for IRQ0 flag) is set to "1" when the interrupt request flag is set to "1", the interrupt control block outputs "1".
- (4) The signal output by the interrupt control block is ANDed with the output of the interrupt enable flip-flop, and an interrupt acknowledge signal is output.
  - This interrupt enable flip-flop is set to "1" by the "EI" instruction and reset to "0" by the "DI" instruction.

    If the interrupt control block outputs "1" while the interrupt enable flip-flop is "1", the interrupt is acknowledged.

As shown in Figure 10-1, the interrupt acknowledge signal is input to each interrupt control block when the interrupt has been acknowledged.

The interrupt request flag is reset to "0" by the signal input to the interrupt control block, and a vector address corresponding to the interrupt is output.

If more than one interrupt block outputs "1" at this time, the interrupt acknowledge signal is not transferred to the next stage. If more than one interrupt request is issued at the same time, therefore, the interrupts are acknowledged in the following priority.

INTo pin > timer

The interrupt of an interrupt source is not acknowledged unless the corresponding interrupt permission flag is set to "1".

If the interrupt permission flag is reset to "0", therefore, an interrupt with a high hardware priority can be disabled.

#### 10.6.2 Timing chart for acknowledging interrupt

Figure 10-4 shows the timing chart illustrating acknowledging interrupts.

- (1) in this figure illustrates how one interrupt is acknowledged.
- (a) in (1) shows the case where the interrupt request flag is lastly set to "1", and (b) in (1) shows the case where the interrupt permission flag is lastly set to "1".

In either case, the interrupt is acknowledged when all the interrupt request flag, interrupt enable flip-flop, and interrupt permission flag are set to "1".

If the last flag or flip-flop that was set to "1" satisfies the first instruction cycle of the "MOVT DBF, @AR" instruction or a given skip condition, the interrupt is acknowledged after the second instruction cycle of the "MOVT DBF, @AR" instruction or the instruction that is skipped (NOP) has been executed.

The interrupt enable flip-flop is set in the instruction cycle next to the one in which the "EI" instruction is executed.

(2) in Figure 10-4 illustrates how more than one interrupt is used.

In this case, the interrupts are sequentially acknowledged according to the hardware priority if all the interrupt permission flags are set. The hardware priority can be changed by manipulating the interrupt permission flag by program.

"Interrupt cycle" shown in Figure 10-4 is a special cycle in which the interrupt request flag is reset, a vector address is specified, and the contents of the program counter are saved after an interrupt has been acknowledged, and lasts for  $4.44 \mu s$ , which is equivalent to the execution time of one instruction.

For further information, refer to 10.7 Operations after Interrupt Has Been Acknowledged.



Figure 10-4. Timing Chart of Acknowledging Interrupt (1/3)

- (1) When one interrupt (e.g., rising of INTo pin) is used
- (a) If interrupt is not masked by interrupt permission flag (IPxxx)
  - <1> If "MOVT" instruction or normal instruction that satisfies skip condition is not executed when interrupt is acknowledged



Note Software macro SET1\_IP0 consists of four instructions.

<2> If "MOVT" instruction or "instruction satisfying skip condition" is executed when interrupt is acknowledged



Note Software macro SET1\_IP0 consists of four instructions.

Figure 10-4. Timing Chart of Acknowledging Interrupt (2/3)

# (b) If interrupt is kept pending by interrupt permission flag



**Note** Software macro SET1\_IP0 consists of four instructions.



Figure 10-4. Timing Chart of Acknowledging Interrupt (3/3)

## (2) When two interrupts (INTo pin and timer) are used

## (a) Hardware priority



**Note** Software macro SET2\_IPTM\_IP0 consists of three instructions.

## (b) Software priority



Note Software macro SET1\_IPTM, SET1\_IP0 consists of four instructions.

## 10.7 Operation After Interrupt Has been Acknowledged

When an interrupt has been acknowledged, the following processing is sequentially executed.

- (1) The interrupt enable flip-flop and the interrupt request flag corresponding to the acknowledged interrupt are reset to "0", disabling the interrupts.
- (2) The contents of the stack pointer are decremented by one.
- (3) The contents of the program counter are saved to the address stack register specified by the stack pointer. The contents saved at this time are the next program memory address that is used after the interrupt has been acknowledged. For example, if a branch instruction is executed, the contents saved are the branch destination address; if a subroutine call instruction is executed, they are the called address. Because the interrupt is acknowledged after the next instruction is executed as a "NOP" instruction if a skip condition is satisfied by a skip instruction, the saved contents are the skipped address.
- (4) The low-order 2 bits of the bank register (BANK) and the index enable flag (IXE) are saved to the interrupt stack.
- (5) The contents of the vector address generator corresponding to the acknowledged interrupt are transferred to the program counter. In other words, execution branches to an interrupt processing routine.

The processing (1) through (5) above is executed in one special instruction cycle (4.44  $\mu$ s) in which the normal instruction is not executed. This instruction cycle is called an interrupt cycle.

In other words, one instruction cycle time is necessary since an interrupt has been acknowledged until execution branches to the corresponding vector address.

## 10.8 Restoring from Interrupt Processing Routine

To restore execution from an interrupt processing routine to the processing that was being performed when the interrupt occurred, a dedicated instruction, "RETI", is used.

When the "RETI" instruction is executed, the following processing is sequentially executed.

- (1) The contents of the address stack register specified by the stack pointer are saved to the program counter.
- (2) The contents of the interrupt stack are restored to the low-order 2 bits of the bank register (BANK) and index enable flag (IXE).
- (3) The contents of the stack pointer are incremented by one.

The processing (1) through (3) above is executed in one instruction cycle in which the "RETI" instruction is executed.

The difference between the "RETI" instruction and subroutine return instructions "RET" and "RETSK" is only the restoring operation of the bank register and index enable flag in (2) above.



# 10.9 External (INTo Pin) Interrupt

## 10.9.1 Outline of external interrupt

Figure 10-5 outlines the external interrupt.

As shown in the figure, the external interrupt issues an interrupt request at the rising edge of the signal input to the INT<sub>0</sub> pin.

The INT<sub>0</sub> pin is a Schmitt trigger input pin to prevent malfunctioning due to noise, and does not accept a pulse less than 1  $\mu$ s wide.

Figure 10-5. Outline of External Interrupt



## 10.9.2 Edge detection block

The edge detection block detects the rising edge that issues the interrupt request of the INTo pin.

86

#### 10.9.3 Pin status detection function

The level of the signal input to the INTo pin can be detected by using software macros.

Therefore, the INT<sub>0</sub> pin can be used as a 1-bit general-purpose input port when it is not used as an interrupt input pin.

Table 10-4 shows the software macros.

These macros are defined in the device file and can be used by INCLUDEing the file supplied with the device file (D17016.INC for the  $\mu$ PD17016 and D17017.INC for the  $\mu$ PD17017) on the source program.

Table 10-4. Software Macros Detecting INTo Pin Level

| Function                                                  | Macro Format |  |  |
|-----------------------------------------------------------|--------------|--|--|
| Skips next instruction if high level is input to INTo pin | SKT1_INT0    |  |  |
| Skips next instruction if low level is input to INTo pin  | SKF1_INT0    |  |  |

## Caution If the above macros are used, the contents of the window register are destroyed.

If an embedded macro instruction is used immediately before the above macro instructions, an "object error" occurs when the source file is assembled and then loaded to the in-circuit emulator. To use an embedded macro instruction immediately before the above macro instructions, insert a comment statement between them.

### 10.10 Internal Interrupt

The timer interrupt is used as the internal interrupt and can issue an interrupt request at fixed time intervals (refer to 11. TIMER FUNCTION).

87

# 10.11 Notes on Using Interrupt

Other interrupts are not acknowledged while a software macro that resets an interrupt request is being executed.

## Example 1.

```
Example 1

Example 2

Example 3

Example 4

Example 4

Example 4

Example 5

Example 6

Example 6

Example 6

Example 7

Exam
```

# Example 2.

```
Example 1

Processing A

CLR1_IRQ0    ← Timer interrupt request is not acknowledged nor kept pending even if it is issued during this period.

Processing B

Example 1

Processing B

Example 2

From Processing B

Example 3

From Processing B

Example 3

From Processing B

Example 3

From Processing B

Example 4

From Processing B

Example 5

From Processing B

Example 5

From Processing B

Example 6

From Processing B

Example 7

From Processing
```

#### 11. TIMER FUNCTION

The timer function is used for time management in developing a program.

## 11.1 Configuration of Timer

Figure 11-1 shows the configuration of the timer block.

As shown in the figure, the timer consists of a timer carry block and a timer interrupt block.

The clock generation circuit that sets the time of each timer divides the system clock by using clock select blocks A and B, and the timer mode select register (RF address 09H) of the control registers.

The following subsections 11.1.1 and 11.1.2 respectively explain the configuration of the timer carry block and that of the timer interrupt block.

Because the clock of each timer is created by dividing the system clock (4.5 MHz), if the frequency of the crystal resonator is not 4.5 MHz, the clock of each timer varies accordingly.

## 11.1.1 Configuration of timer carry block

The timer carry block consists of clock select block A and timer carry FF block.

## 11.1.2 Configuration of timer interrupt block

The timer interrupt block consists of clock select block B and interrupt control block.

Figure 11-1. Configuration of Timer Block

## • Timer carry block



## • Timer interrupt block





#### 11.2 Functional Outline of Timer

The timer can be used in two ways: by detecting the carry FF of the timer carry and by using the interrupt of the timer.

The following subsections 11.2.1 and 11.2.2 respectively outline the functions of the timer carry and timer interrupt.

## 11.2.1 Functional outline of timer carry

The timer carry manages time by detecting by program the status of the timer carry FF that is set at fixed intervals.

Refer to 11.3 Timer Carry.

## 11.2.2 Functional outline of timer interrupt

The timer interrupt manages time by issuing an interrupt request at fixed time intervals.

Refer to 11.4 Timer Interrupt.

## 11.3 Timer Carry

## 11.3.1 Configuration of timer carry

Figure 11-2 shows the configuration of the timer carry.

As shown in the figure, the timer carry consists of a divider, selector, and timer carry FF block.

Control register Name Timer mode Timer carry select FF judge Address 09H 17H Bit  $b_2$ b<sub>1</sub>  $b_0$ рз b<sub>2</sub>\ b<sub>1</sub>  $b_0$ В В В В Flag symbol В 0 0 Μ Μ Μ 1 0 0 1 0 Ċ Ċ Č K Č C K 0 1 0 Selector 250 ms 🔾 100 ms 🔾 4.5 MHz Divider Timer carry FF 5 ms () 1 ms 🔾

Figure 11-2. Configuration of Timer Carry

#### 11.3.2 Function of timer carry

The timer carry is set to 1 at the rising edge of the timer carry FF setting pulse that is set by the low-order 2 bits (BTM0CK1 and BTM0CK0 flags) of the timer mode select register.

The content of the timer carry FF corresponds to the least significant bit (BTM0CY flag) of the timer carry FF judge register (RF address 17H) on a one-to-one basis. If the timer carry FF is set to "1", therefore, the BTM0CY flag is also set to "1".

The BTM0CY flag is reset to "0" when data is written to the window register by the "PEEK" instruction (Read & Reset).

When the BTM0CY flag is reset to "0", the timer carry FF is also reset to "0".

Therefore, a timer that is set via the timer mode select register can be used by reading the contents of the BTM0CY flag by program.

When using the timer carry, note the following.

Caution The timer carry is disabled from being set on application of the supply voltage V<sub>DD</sub> (on power-ON reset), and is not set to "1" until the content of the BTM0CY flag is once read by the "PEEK" instruction.

This means that "0" is always read from the BTM0CY flag immediately after power-ON reset, and that the flag is set to "1" at time intervals set by the timer mode select register.

The timer carry also controls the timing of the reset operation by the CE pin (CE reset). If the CE pin goes high, CE reset is effected in synchronization with the timing that sets the timer carry FF to "1".

Therefore, a power failure can be detected by reading the content of the BTM0CY flag at system reset (power-ON reset and CE reset).

For details, refer to 11.3.7 Notes on using timer carry.

Because the BTM0CY flag is a read-only flag, the device operation is not affected in any way even if data is written to this flag by using the "POKE" instruction. However, an error occurs if the 17K Series assembler is used.

For details, refer to 8.4 Notes on Using Register File.



## 11.3.3 Configuration and function of timer mode select register

The timer mode select register sets the time interval of the timer carry and the timer interrupt of the internal timer.

These two time intervals can be set independently.

Figure 11-3 shows the waveform of a timer time setting pulse.



Note For the details on the timer interrupt, refer to 11.4 Timer Interrupt.

Figure 11-3. Waveform of Timer Time Setting Pulse





## 11.3.4 Configuration and function of timer carry FF judge register

The timer carry FF judge register detects the status of the timer carry FF of the internal timer. The configuration and function of this register are illustrated below.



The BTM0CY flag is set to "1" at time intervals set by the timer mode select register.

The BTM0CY flag is detected by the "PEEK" instruction via the window register.

If the BTM0CY flag is set to "1" at this time, the value of the flag is transferred to the window register, and then the BTM0CY flag is reset to "0" (Read & Reset).

The BTM0CY flag is "0" on power-ON reset, but "1" on CE reset (including CE reset that is executed in the clock stop status); therefore, it can be used as a power failure detection flag.

The BTM0CY flag is not set to "1" until it is read once by the "PEEK" instruction after power-ON reset. Once the "PEEK" instruction has been executed, it is set to "1" at the time interval set by the timer mode select register.

### 11.3.5 Example of using timer with BTM0CY flag

Here is an example program.

## Example



This program executes processing A every 1 second.

In developing a program, the following point must be noted.

# Caution Keep the time interval at which the BTM0CY flag is detected shorter than the time interval at which the timer carry FF is set to 1.

This is because, in the above example, if the execution time of processing B is longer than 250 ms, setting of the timer carry FF is not detected.

Figure 11-4. Detection of BTM0CY Flag and Timer Carry FF

Because the execution time of processing B' is long, after the BTM0CY flag set in <2> has been detected, the status of BTM0CY flag that is set in <3> is not detected.



### 11.3.6 Error of timer caused by BTM0CY flag

The error of the timer caused by the BTM0CY flag includes an error caused by the detection time of the BTM0CY flag and an error that occurs when the set time of the timer carry FF is changed.

# (1) Error caused by detection time of BTM0CY flag

As explained in 11.3.5, the time interval at which the BTM0CY flag is detected must be shorter than the time interval at which the timer carry FF is set to 1.

Where the time interval at which the BTM0CY flag is detected is tcheck and the time interval at which the timer carry FF is set is tset (250, 100, 5, or 1 ms), the following relation must be satisfied.

tcheck < tset

The error of the timer when the BTM0CY flag is detected as shown in Figure 11-5 is as follows.

0 < error < tcheck

Figure 11-5. Error Caused by Detection Time of BTM0CY Flag



As shown in Figure 11-5, the timer is updated when the BTM0CY flag is detected in <2> because it is "1". When the flag is 0 when it is detected in <3> next. Therefore, the timer is not updated until the flag is detected again in <4>.

At this time, the time of the timer is prolonged by the time of tchecks.

#### (2) Error when changing set time of timer carry FF

The set time of the timer carry FF is set by the BTM0CK1 and BTM0CK0 flags of the timer mode select register.

Four types of timer time setting pulses, 1 kHz, 200 Hz, 10 Hz, and 4 Hz, can be selected as shown in Figures 11-2 and 11-3.

These four pulses operate independently.

If the timer time setting pulse is changed by using the BTM0CK1 and BTM0CK0 flags, an error occurs as shown in the following example.

## **Example**

; <1>

INITFLG BTM0CK1, NOT BMT0CK0 ; Embedded macro

; Sets timer carry FF setting pulse to

; 200 Hz (5 ms)

Processing A

; <2>

SET2 BTM0CK1, BTM0CK0 ; Embedded macro

; Sets timer carry FF setting pulse to

; 1 kHz (1 ms)

Processing A

; <3>

INITFLG BTM0CK1,NOT BTM0CK0 ; Embedded macro

; Sets timer carry FF setting pulse to

; 200 Hz (5 ms)

The timer carry FF setting pulse is changed as follows at this time.



When the set time of the timer carry FF is changed as shown above, the BTM0CY flag holds the previous status (<2> in the figure) if the changed pulse falls, but is set to 1 (<3> in the figure) if the pulse rises.



In the previous example, the timer time setting pulse is changed between 200 Hz (5 ms) and 1 kHz (1 ms). The same applies when the pulse is changed between 4 Hz (250 ms) and 10 Hz (100 ms).

Therefore, an error until the BTM0CY flag is set first when the timer carry FF setting time is changed as shown in Figure 11-6 is as follows.

-tset < error < tcheck

where,

tset : new timer carry FF setting time tcheck : time to detect BTM0CY flag

The internal pulses of 4 Hz, 10 Hz, 200 Hz, and 1 kHz have a phase difference. This phase difference is included in the above error because it is shorter than the time of the new pulse.

For the phase difference of each pulse, refer to 11.4.5 Notes on using timer interrupt.

Figure 11-6. Error When Timer Carry FF Setting Time Is Changed from A to B



#### 11.3.7 Notes on using timer carry

The timer carry is also used as a reset synchronization signal when reset is effected by the CE pin (CE reset), not only for the timer function.

The CE reset is effected if the timer carry FF setting pulse rises the next time after the CE pin has gone high. At this time, the following points must be noted.

- (1) The sum of the timer updating processing time and the BTM0CY flag detection time must be shorter than the timer carry FF setting time.
- (2) If a program is created in which the timer always operates at a fixed interval regardless of CE reset after application of the supply voltage (power-ON reset), correction must be made each time CE reset is effected.
- (3) Detection of the BTM0CY flag takes precedence over the reset synchronization signal on CE reset. If these two coincide, therefore, CE reset is delayed once.
- (1) through (3) above are explained in more detail in the following (a) through (c).



#### (a) Timer updating processing time and detection time interval of BTM0CY flag

As explained in 11.3.6, the time interval tset at which the BTM0CY flag is detected must be shorter than the time interval at which the timer carry FF is set.

If the updating processing time of the timer is long even if the time interval to detect the BTM0CY flag is short, the timer processing may not be executed normally if CE reset is effected.

Therefore, the following condition must be satisfied.

tcheck + ttimer < tset

where,

tcheck: time interval to detect BTM0CY flag
ttimer: timer updating processing time
tset: time to set timer carry FF

Here is an example.

## Example Example of timer updating processing and BTM0CY flag detection time interval

```
; Program address 0000H
START:
       CLR2
                BTM0CK1, BTM0CK0
                                  : Embedded macro
                                  ; Sets set time of timer carry FF to 100 ms
TIMER:
      ; <1>
             SKT1 BTM0CY
                                  ; Embedded macro
                                  ; Tests BTM0CY flag; if "0", branches to AAA
             BR
                   AAA
               Timer update
             BR
                   TIMER
AAA:
               Processing A
             BR
                   TIMER
```

The timing chart of the above program is shown below.



#### (b) Correction of timer carry on CE reset

An example of correcting the timer at CE reset is shown below.

As shown in this example, the timer must be corrected on CE reset if "the timer carry is used to detect a power failure and the timer carry is also used as a watch timer".

The timer carry is reset to "0" on first power application (power-ON reset), and afterward, is disabled from being set until the BTM0CY flag is read once by the "PEEK" instruction.

If the CE pin goes high, CE reset is effected in synchronization with the rising edge of the timer carry FF setting pulse. At this time, the BTM0CY flag is set to "1" and the program is started.

Therefore, it is judged that power-ON reset has been effected if the BTM0CY flag is "0" and that CE reset has been effected if the BTM0CY flag is "1", by detecting the status of the BTM0CY flag on system reset (power-ON reset or CE reset). A power failure can be detected in this way.

At this time, the watch timer must continue operating even on CE reset.

However, because the BTM0CY flag is reset to "0" when the flag is read to detect a power failure, the set "1" status of the BTM0CY flag is overlooked once.

Therefore, the watch timer must be updated if it is judged by means of power failure detection that CE reset has been effected.

For the details on power failure detection, refer to 13.6 Power Failure Detection.

# Example Example of correcting timer on CE reset (to detect power failure and update watch by timer carry)



Figure 11-7 shows the timing chart of the above program.





Figure 11-7. Timing Chart

As shown in Figure 11-7, the program is started from address 0000H at the rising edge of the internal 10-MHz pulse when supply voltage  $V_{\text{DD}}$  is applied first.

When the BTM0CY flag is detected at point A, the BTM0CY flag is reset to "0" because power has been just applied, and it is judged that a power failure (power-ON reset) has occurred.

Therefore, "processing C" is executed and the timer carry FF setting pulse is set to 100 ms.

Because the contents of the BTM0CY flag are read once at point A, the BTM0CY flag is set to "1" every 100 ms.

Next, the program counts up the watch while executing "processing B" even if the CE pin goes low at point B and high at point C, unless the clock stop instruction is executed.

Because the CE pin goes high at point C, CE reset is effected at point D where the pulse for setting the next timer carry FF rises and the program is started from address 0000H.

Because the BTM0CY flag is set to "1" when it is detected at point E at this time, it is judged that back up (CE reset) has been performed.

As is evident from the figure, the watch is delayed by 100 ms each time CE reset is effected unless the watch is updated by 100 ms at point E.

If processing A takes longer than 100 ms when a power failure is detected at point E, setting of the BTM0CY flag is overlooked two times; therefore, processing A must be completed in less than 100 ms.

The same applies when the timer carry FF setting pulse is set to 250, 5, or 1 ms.

Therefore, the BTM0CY flag must be detected to detect a power failure within the timer carry FF setting time after the program has started from address 0000H.

#### (c) If BTM0CY flag is detected at same time as CE reset

As explained in (b), CE reset is effected if the BTM0CY flag is set to "1".

If an instruction that reads the BTM0CY flag happens to be executed at the same time as CE reset, execution of the instruction that reads the BTM0CY flag takes precedence.

Therefore, if the next setting of the BTM0CY flag (rising of the timer carry FF setting pulse) after the CE pin has gone high is performed at the same time as the instruction that reads the

BTM0CY flag, CE reset is effected "when the BTM0CY flag is set next".

This operation is illustrated in Figure 11-8.

Figure 11-8. Operation When CE Reset Is Executed At Same Time As Instruction
That Reads BTM0CY Flag



Program is supposed to start from address 0000H at this time, but CE reset is not effected because program that reads BTM0CY takes precedence.

Therefore, a program that periodically detects the BTM0CY flag never executes a CE reset if the detection interval of the BTM0CY flag is the same as the setting time of the TMCY flag.

This must be prevented as follows.

Because one instruction cycle is 4.44  $\mu$ s (1/225 kHz), a program, for example, that detects the BTM0CY flag once every 255 instructions reads the BTM0CY flag every 1 ms = 4.44  $\mu$ s  $\times$  225.

Once detection and setting of the BTM0CY flag coincide, CE reset is never effected no matter which of 1, 5, 100, or 250 ms of the timer time setting pulse is selected.

Therefore, do not develop a program that has a cycle satisfying the following condition.

$$\frac{\text{tset} \times 225}{X} = \text{n (n: natural number)}$$

where,

tset : setting time of BTM0CY flag

X : period x number of steps of instruction that reads BTM0CY flag

An example of a program that satisfies this condition is shown below. Do not develop such a program.



## Example



In this example, the instruction <1> that reads the BTM0CY flag is repeatedly executed every 225 instructions. If the BTM0CY flag is set at the timing of the instruction <1>, therefore, CE reset is not effected.



# 11.4 Timer Interrupt

## 11.4.1 Configuration of timer interrupt

Figure 11-9 shows the configuration of the timer interrupt.

As shown in the figure, the timer interrupt consists of a divider, selector, and interrupt control flag.

Control register Timer mode Name select Address 09H Bit  $b_1$ bз  $b_2$  $b_0$ B T В В Flag symbol В М M Μ Μ 1 C 1 C K 0 C K 1 0 C K 0 K 1 0 Selector Issuance of IPTM flag 250 ms 🔾 interrupt request 100 ms 🔾 IRQTM flag 4.5 MHz Divider 5 ms 🔾 1 ms 🔾

Figure 11-9. Configuration of Timer Interrupt

**Remark** The interrupt permission flag (IPTM) is set by a software macro. The interrupt request flag (IRQTM) can be reset by software. For details, refer to **10. INTERRUPT**.



#### 11.4.2 Function of timer interrupt

The timer interrupt request is issued at the falling edge of a timer interrupt pulse set by the high-order 2 bits (BTM1CK1 and BTM1CK0 flags) of the timer mode select register (refer to **11.3.3**).

The timer interrupt request corresponds to the IRQTM flag on a one-to-one basis. When the timer interrupt request is issued, the IRQTM flag is set to "1".

In other words, the IRQTM flag is set to "1" if the timer interrupt pulse falls.

So that the timer interrupt is acknowledged, the "EI" instruction that enables all the interrupts must be executed and the timer interrupt must be enabled, in addition to issuance of the interrupt request as explained in 10. Interrupt.

The timer interrupt is enabled by setting the IPTM flag to "1".

Therefore, the timer interrupt is acknowledged if the IRQTM flag is set to "1" when the "EI" instruction is executed and the IPTM flag is set to "1".

The IPTM flag is set by a software macro. For the macro that enables or disables an interrupt, refer to **Table 10-2. Software Macros Enabling/Disabling Interrupts**. The IRQTM flag cannot be set by software.

When the timer interrupt is acknowledged, the program execution branches to program memory address 0003H. The IRQTM flag is reset to "0" as soon as the interrupt has been acknowledged.

Figure 11-10 shows the relation between the timer interrupt pulse and IRQTM flag.



Figure 11-10. Relation between Timer Interrupt Pulse and IRQTM Flag

A point to be noted is that, as shown in point <1> in the above figure, the timer interrupt is acknowledged when the "EI" instruction is executed next and the IPTM flag is set once the IRQTM flag has been set when the timer interrupt is disabled by the "DI" instruction or IPTM flag.

In this case, the interrupt request can be cleared by executing a software macro that resets the interrupt request (refer to **Table 10-1. Software Macros That Reset Interrupt Requests**).

One level of the stack is used when the timer interrupt is acknowledged.

At this time, the contents of the register bank (BANK: address 79H) and the content of the index enable flag (IXE: bit 0 of address 7FH) are automatically saved.

To return from the interrupt processing routine, use a dedicated instruction "RETI".

For details, refer to 3. ADDRESS STACK (ASK) and 10. INTERRUPT.

The following subsections 11.4.3 and 11.4.4 explain an example of using the timer interrupt and an error of the timer interrupt.

For the relation between the timer interrupt and the other interrupt (INT₀ pin), refer to 10. INTERRUPT.



#### 11.4.3 Example of using timer with timer interrupt

#### Example

М1 MEM 0.10H ; 80-ms counter ; Symbol definition of timer interrupt vector address DAT 0003H TIMER BR START ; Branches to START ; Program address (0003H) ORG TIMER M1, #0001B; Adds 1 to M1 ADD ; Tests CY flag SKT1 CY BR ; Return if carry does not occur EI\_RETI Processing A EI\_RETI: ΕI RETI START: INITFLG BTM1CK1, NOT BTM1CK0 ; Embedded macro ; Sets timer interrupt pulse to 5 ms M1, #0000B; Clears contents of M1 MOV ; Enables timer interrupt (software macro) SET1\_IPTM ; Enables all interrupts ΕI LOOP: Processing B BR LOOP

The above program executes processing A every 80 ms.

The points to be noted at this time are that the DI status is automatically set when the interrupt is acknowledged, and that the IRQTM flag is set to "1" even in the DI status.

If processing A takes longer than 5 ms, therefore, the interrupt is acknowledged even if the "RETI" instruction is executed.

Consequently, processing B is not executed.



#### 11.4.4 Error of timer interrupt

As explained in 11.4.2, the timer interrupt is acknowledged each time the timer interrupt pulse falls if the EI instruction is executed and the timer interrupt is enabled.

Therefore, an error of the timer when the timer interrupt is used occurs only in the following cases (1) through (3).

- (1) When the first interrupt is acknowledged with the timer interrupt enabled
- (2) When the first interrupt is acknowledged with the time of the timer interrupt pulse changed
- (3) If the software macro that resets the timer interrupt request is executed at the same time as the falling of the timer interrupt pulse (the interrupt is not acknowledged)

Figure 11-11 shows the errors that may occur in each of the above cases.

Figure 11-11. Error of Timer Interrupt (1/2)

#### (a) When timer interrupt is enabled



At point <1> in the above figure, the timer interrupt is acknowledged immediately if the interrupt is enabled by setting the IPTM flag.

At this time, the error is -tset.

If the interrupt is enabled by the "EI" instruction at point <2>, the interrupt occurs at the falling edge of the timer interrupt pulse at point <3>.

At this time, the error is -tset < error < 0.

Figure 11-11. Error of Timer Interrupt (2/2)

## (b) If timer interrupt pulse is changed



Because the timer interrupt pulse does not fall even if the timer interrupt pulse is changed to B at point <1>, the interrupt is acknowledged at the next point <2>.

If the timer interrupt pulse is changed to A at point <3>, the timer interrupt pulse falls, and the interrupt is immediately acknowledged.



#### 11.4.5 Notes on using timer interrupt

When developing a program in which the timer always operates after the supply voltage VDD has been once applied (power-ON reset) by using the timer interrupt, such as a watch program, the timer interrupt processing must be completed within specific time.

Take the following program for example.

#### Example

```
M 1
         MEM
                    0.10H
                                   ; 1-ms counter
                                   ; Symbol definition of interrupt vector address
TIMER
         DAT
                    0003H
                                   ; Branches to START
         BR
                    START
                                  ; Program address (0003H)
ORG
         TIMER
                                 ; Adds 0100B to contents of M1
         ADD
                    M1, #0100B
         SKT1
                                   ; Watch processing if carry occurs
                    CY
         BR
                    EI_RETI
                                   ; Return if carry does not occur
       ; <1>
          Watch processing
EI_RETI:
         EΙ
         RETI
START:
         INITFLG NOT BTM1CK1, BTM1CK0, NOT BTM0CK1, NOT BTM0CK0
                                  ; Embedded macro
                                   ; Sets timer interrupt time to 250 ms and timer carry FF
                                   ; setting time to 100 ms
                                   ; Enables timer interrupt (software macro)
         SET1_IPTM
                                   ; Enables all interrupts
         ΕI
LOOP:
            Processing A
         BR
                    LOOP
```

In this example, watch processing <1> is executed every 1 second while processing A is executed.

If the CE pin goes high, CE reset is effected in synchronization with the rising of the timer carry FF setting pulse, as shown in Figure 11-12 (a).

If the timer interrupt request (IRQTM flag) is issued at the same time as setting of the timer carry FF, CE reset takes precedence.

When CE reset is effected, the IRQTM flag is automatically reset to "0".

In other words, timer processing is not executed once if the CE reset is effected while the IRQTM flag is set to "1".

To prevent this, a delay time is provided between "rising of the timer carry FF setting pulse" and "falling of the timer interrupt pulse" as shown in Figure 11-12(b).

In the above example, the timer interrupt is not overlooked even if the CE reset is effected if the watch processing is executed within 10 ms as shown in Figure 11-12(b).

Because the timer carry FF and timer interrupt time setting pulse can be set to 4 Hz (250 ms), 10 Hz (100 ms), 200 Hz (5 ms), or 1 kHz (1 ms) independently, time differences shown in Figure 11-13 and Table 11-1 are provided.

To validate the timer interrupt at CE reset, therefore, the processing of the timer interrupt must be completed within the delay time of the pulse as shown in Figure 11-13.

Figure 11-12. Timing Chart







1 ms BTM0CY 1 ms INT 5 ms 1 ms BTM0CY 5 ms INT Dummy 10 ms 100 ms BTM0CY 100 ms INT 250 ms BTM0CY 250 ms INT

Figure 11-13. Time Difference between Timer Carry FF Setting Pulse and Timer Interrupt Pulse

Table 11-1. Time Difference between Rising Edge of Timer Carry FF Pulse and Falling Edge of Timer Interrupt Pulse

| Interr      | nal Pulse       | Minimum Value of Time Difference (Refer to figure below.) |                |  |
|-------------|-----------------|-----------------------------------------------------------|----------------|--|
| Timer carry | Timer interrupt | t <sub>1</sub>                                            | t <sub>2</sub> |  |
| 1 ms        | 1 ms            | 666 μs                                                    | 333 μs         |  |
| 1 ms        | 5 ms            | 333 μs                                                    | 666 μs         |  |
| 1 ms        | 100 ms          | 333 μs                                                    | 666 μs         |  |
| 1 ms        | 250 ms          | 333 μs                                                    | 666 μs         |  |
| 5 ms        | 1 ms            | 333 μs                                                    | 666 μs         |  |
| 5 ms        | 5 ms            | 3 ms                                                      | 2 ms           |  |
| 5 ms        | 100 ms          | 2 ms                                                      | 3 ms           |  |
| 5 ms        | 250 ms          | 2 ms                                                      | 3 ms           |  |
| 100 ms      | 1 ms            | 333 μs                                                    | 666 μs         |  |
| 100 ms      | 5 ms            | 1 ms                                                      | 4 ms           |  |
| 100 ms      | 100 ms          | 50 ms                                                     | 50 ms          |  |
| 100 ms      | 250 ms          | 10 ms                                                     | 40 ms          |  |
| 250 ms      | 1 ms            | 333 μs                                                    | 666 μs         |  |
| 250 ms      | 5 ms            | 1 ms                                                      | 4 ms           |  |
| 250 ms      | 100 ms          | 40 ms                                                     | 10 ms          |  |
| 250 ms      | 250 ms          | 100 ms                                                    | 150 ms         |  |





#### 12. STANDBY

The standby function is used to reduce the current consumption of the device during back up.

# 12.1 Configuration of Standby Block

Figure 12-1 shows the configuration of the standby block.

As shown in the figure, the standby block is divided into two blocks: halt control block and clock stop control block.

The halt control block consists of a halt control circuit, interrupt control block, timer carry, and key input pins P0D<sub>0</sub>/ADC<sub>2</sub> through P0D<sub>3</sub>/ADC<sub>5</sub>, and controls the operation of the CPU (program counter, instruction decoder, and ALU block).

The clock stop control block controls the 4.5-MHz crystal oscillation circuit, CPU, system register, and control registers, by using the clock stop control circuit.



Figure 12-1. Configuration of Standby Block

## 12.2 Standby Function

The standby function reduces the current consumption of the device by stopping some or all the operations of the device.

The standby function can be used in two modes: halt and clock stop.

The halt mode is to reduce the current consumption of the device by executing a dedicated instruction "HALT h" and stopping the operation of the CPU.

The clock stop mode is to reduce the current consumption of the device by executing a dedicated instruction "STOP s" and stopping the 4.5-MHz crystal oscillation circuit.

In addition to the halt and clock stop modes, the operation mode of the device can be also set by the CE pin.

The CE pin is used to control the operation of the PLL frequency synthesizer and reset the device, and can be said to be a type of the standby function in that it controls the operation of the PLL frequency synthesizer.

The following section 12.3 explains how to set the operation mode of the device by using the CE pin.

Sections 12.4 and 12.5 respectively explain the halt and clock stop modes.

# 12.3 Selecting Device Operation Mode with CE Pin

The CE pin controls the following functions (1) through (3) by using the level and rising edge of an externally input signal.

- (1) Controls operation of PLL frequency synthesizer
- (2) Enables or disables clock stop instruction
- (3) Resets device

## 12.3.1 Controlling operation of PLL frequency synthesizer

The PLL frequency synthesizer can operate only when the CE pin is high.

The PLL frequency synthesizer is automatically disabled when the CE pin is low.

At this time, the VCOH and VCOL pins are internally pulled down, and the EOo and EO1 pins are floated.

The PLL frequency synthesizer can be disabled by program at any time when the CE pin is high.

#### 12.3.2 Enabling and disabling clock stop instruction

The clock stop instruction "STOP s" is enabled only when the CE pin is low.

The "STOP s" instruction is executed as a no-operation (NOP) instruction if it is executed when the CE pin is high.

#### 12.3.3 Resetting device

The device can be reset (CE reset) by raising the CE pin.

The device can also be reset through power application (power-ON reset).

For details, refer to 13. RESET.



#### 12.3.4 Inputting signal to CE pin

The CE pin does not accept a low or high level of less than 110 to 165  $\mu$ s to prevent malfunctioning due to noise.

The level of the signal input to the CE pin can be detected by using the CE flag of the CE pin level judge register (RF address 07H).

Figure 12-2 shows the relation between the input signal and CE flag.

Figure 12-2. Relation between Signal Input to CE Pin and CE Flag



#### 12.3.5 Configuration and function of CE pin level judge register

The CE pin level judge register detects the level of the signal input to the CE pin.

The configuration and function of this register are illustrated below.



The CE flag is not affected by a low or high level of less than 110 to 165  $\mu$ s.

#### 12.4 Halt Function

The halt function stops the operation clock of the CPU by executing the "HALT h" instruction.

When the "HALT h" instruction is executed, the program stops at the "HALT h" instruction, until the halt status is released later.

Therefore, the current consumption of the device can be reduced in the halt status by the operating current of the CPU.

The halt status can be released by key input, timer carry, or interrupt.

The releasing condition of the key input, timer carry, and interrupt is specified by the operand "h" of the "HALT h" instruction.

The "HALT h" instruction is valid regardless of the input level of the CE pin.

The following subsections 12.4.1 through 12.4.6 explain the halt status, halt release condition, and each halt release condition.

#### 12.4.1 Halt status

All the operations of the CPU are stopped in the halt status.

In other words, program execution is stopped at the "HALT h" instruction.

However, the peripheral hardware units continue the operations set before the "HALT h" instruction is executed.

For the operations of the peripheral hardware units, refer to 12.6 Device Operations in Halt and Clock Stop Status.



#### 12.4.2 Halt release condition

Figure 12-3 shows the halt release conditions.

As shown in this figure, the halt release conditions are set by 4-bit data specified by operand "h" of the "HALT h" instruction.

The halt status is released when the condition specified as "1" by operand "h" is satisfied.

When the halt status is released, the execution starts from the instruction next to the "HALT h" instruction.

If two or more release conditions are specified, and if any one of the specified conditions is satisfied, the halt condition is released.

If the device is reset (power-ON reset or CE reset), the halt status is released, and each reset operation is performed.

If 0000B is set as the halt release condition "h", no release condition is set.

At this time, the halt status is released if the device is reset (power-ON reset or CE reset).

The following subsections 12.4.3 through 12.4.5 explains halt release conditions set by key input, timer carry, and interrupt.

12.4.6 shows an example when two or more release conditions are specified.



Figure 12-3. Halt Release Condition

#### 12.4.3 Releasing halt status by key input

Releasing the halt status by key input is specified by the "HALT 0001B" instruction.

If releasing the halt status by key input is specified, the halt status is released when a high level is input to any of the four pins P0D<sub>0</sub>/ADC<sub>2</sub> through P0D<sub>3</sub>/ADC<sub>5</sub>.

The following paragraphs (1) through (4) explain the points to be noted when using a general-purpose output port for a key source signal, when multiplexing LCD segment signal output with key source signal output, and when using one of the P0D<sub>0</sub>/ADC<sub>2</sub> through P0D<sub>3</sub>/ADC<sub>5</sub> pins as an A/D converter pin.

## (1) Notes on using general-purpose output port for key source signal



The "HALT 0001B" instruction is executed after a general-purpose output port for key source signal goes high. If an alternate switch such as switch A in the above figure is used at this time, a high level is always applied to the P0D<sub>0</sub>/ADC<sub>2</sub> pin while switch A is closed, and the halt status is immediately released.

Therefore, care must be execised in using the alternate switch.

When using a general-purpose output port for key source signal, reset the KSEN flag of the LCD mode select register (RF address 10H) to "0".

At this time, the P0D<sub>0</sub>/ADC<sub>2</sub> through P0D<sub>3</sub>/ADC<sub>5</sub> pins are automatically pulled down.



#### (2) Notes on multiplexing LCD segment signal output and key source signal output



Execute the "HALT 0001B" instruction after setting key source signal output data.

At this time, the halt status is not released even if a high level of the LCD segment signal is input to the pin whose key source signal output data is "0".

To multiple LCD segment signal output with key source signal output, set the KSEN flag of the LCD mode select register to 1.

The key source signal data (setting the pin that outputs a key source) is set by the key source data register (KSR: peripheral address 42H) via the data buffer.

The internal key latch circuit when LCD segment signal output is multiplexed with key source signal output latches data only while the key source signal is output, and is disconnected from the external source while the LCD segment signal is output.

The internal pull-down resistor is ON only when the key source signal is output.

#### (3) Notes on using P0D<sub>0</sub>/ADC<sub>2</sub> to P0D<sub>3</sub>/ADC<sub>5</sub> pin as A/D converter pin



When any of the P0D<sub>0</sub>/ADC<sub>2</sub> through P0D<sub>3</sub>/ADC<sub>5</sub> pins is used as an A/D converter pin, the selected pin (only one pin can be selected at one time) is disconnected from the input latch and is connected to the internal A/D converter input.

If a high level is input to the pin selected as an A/D converter pin at this time, the latch circuit holds the high level.

If the "HALT 0001H" instruction is executed in this status, the halt status is immediately released even if the instruction can be executed because the input latch is at high level.

To prevent this, set the pin in the input port mode before executing the "HALT 0001H" instruction, and set a low level for A/D converter input.

## (4) Others



The  $P0D_0/ADC_2$  through  $P0D_3/ADC_5$  pins can also be used as general-purpose input port pins with pull-down resistors.

Therefore, the halt status can also be controlled by using an external microcontroller as shown above.



#### 12.4.4 Releasing halt status by timer carry

Releasing the halt status by the timer carry is set by the "HALT 0010B" instruction.

When the release of the halt status is set by the timer carry, the halt status is released as soon as the timer carry FF has been set to "1".

The timer carry FF corresponds to the BTM0CY flag of the timer carry FF judge register on a one-to-one basis, as explained in 11. TIMER FUNCTION, and is set to "1" at fixed time intervals (1 ms, 5 ms, 100 ms, or 250 ms).

Therefore, the halt status can be released at fixed time intervals.

## Example

0.10H ; 1-second counter М1 MEM 0010B ; Symbol definition HITTMR DAT CLR2 BTM0CK1, BTM0CK0 ; Embedded macro ; Sets timer carry FF setting time to 250 ms LOOP: ; Sets release condition by timer carry FF and halt status HALT HLTTMR SKT1 BTM0CY ; Embedded macro ; Branches to LOOP if BTM0CY flag is not set BR LOOP M1, #0100B; Adds 0100B to contents of M1 ADD : Embedded macro SKT1 CY ; Executes processing A if carry occurs BR LOOP Processing A LOOP BR

In this example, the halt status is released every 250 ms and processing A is executed every 1 second.

## 12.4.5 Releasing halt status by interrupt

Releasing the halt status by an interrupt is set by the "HALT 1000B" instruction.

If releasing the halt status by an interrupt is set, the halt status is released as soon as the interrupt has been acknowledged.

Two interrupt sources, INT₀ pin and timer, are available as explained in 10. INTERRUPT.

Therefore, the interrupt source to be used to release the halt status must be specified by program in advance.

So that the interrupt is acknowledged, all the interrupts must be enabled (by the EI instruction), each interrupt is enabled (by setting the corresponding interrupt permission flag), in addition that the interrupt request must be issued from each interrupt source.

Even if an interrupt request is issued, if that interrupt is not enabled, the interrupt is not acknowledged and the halt status is not released.

When the halt status has been released because the interrupt has been acknowledged, the program flow branches to the vector address of the interrupt.

If the "RETI" instruction is executed after the interrupt processing, the program flow returns to the instruction next to the "HALT" instruction.

Here is an example.

#### Example

```
HLTINT
          DAT
                    1000B
                             ; Symbol definition of halt condition
                             ; Interrupt vector address symbol definition
          DAT
                    0003H
INTTM
INTOPIN DAT
                    0005H
                             ; Program address 0000H
START:
          BR
                    MAIN
ORG
          INTTM
                             ; Timer interrupt vector address (0003H)
          BR
                    INTTIMER
ORG
          INTOPIN
                             ; INTo pin interrupt vector address (0005H)
           Processing A
                             ; Interrupt processing by INTo pin
          BR
                    EI_RETI
INTTIMER:
           Processing B
                             ; Interrupt processing by timer
EI_RETI:
          ΕI
          RETI
MAIN:
          SET2_IPTM_IP0 ; Software macro
                    BTM1CK1, BTM1CK0
          SET2
                             ; Embedded macro
                             ; Sets time interval of timer interrupt to 1 ms
LOOP:
           Processing C
                             ; Main routine processing
                             ; Enables all interrupts
          ET
                    HLTINT; Specifies releasing halt by interrupt
          HALT
       ; <1>
          BR
                    LOOP
```

In this example, the halt status is released when the timer interrupt is acknowledged, and processing B is executed. When the INTo pin interrupt is acknowledged, processing A is executed.

Each time the halt status is released, processing C is executed.

If the INT<sub>0</sub> pin interrupt request and timer interrupt request are issued at the same time in the halt status, processing A of the INT<sub>0</sub> pin, which has the higher hardware priority, is executed.

If "RETI" is executed after execution of processing A, execution restores to the "BR LOOP" instruction in <1>, but the "BR LOOP" instruction is not executed, and the timer interrupt is immediately acknowledged.

If "RETI" is executed after processing B of the timer interrupt has been executed, the "BR LOOP" instruction is executed.



# Caution When executing the HALT instruction which is to be released if the interrupt request flag (IRQxxx) for which the interrupt permission flag (IPxxx) is set is set, describe a NOP instruction

immediately before the HALT instruction.

If a NOP instruction is described immediately before the HALT instruction, a time of one instruction is generated in between the IRQXXX manipulation instruction and HALT instruction. In the case of the CLR1 IRQXXX instruction, for example, clearing IRQXXX is correctly reflected on the HALT instruction (refer to Example 1 below). If a NOP instruction is not described immediately before the HALT instruction, the CLR1 IRQXXX instruction is not correctly reflected on the HALT instruction, and the HALT mode is not set (refer to Example 2 below).

Example 1. Program that correctly executes HALT instruction



#### 2. Program that does not set HALT mode

|      |        | ; Sets IQR×××                                                                              |
|------|--------|--------------------------------------------------------------------------------------------|
| CLR1 | IRQXXX | ; Clearing IRQxxx is not reflected on HALT instruction ; (but on instruction next to HALT) |
| HALT | 1000B  | ; HALT instruction is ignored (HALT mode is not set)                                       |

#### 12.4.6 If two or more release conditions are simultaneously set

If two or more release conditions are simultaneously set, and if even one of the conditions is satisfied, the halt status is released.

The method to identify the release condition that is satisfied when two or more release conditions are specified is shown below.

#### Example 1.

```
HLTINT
                   DAT
                          1000B
         HLTTMR
                   DAT
                          0010B
                          0001B
         HLTKEY
                    DAT
                                          ; INTo pin interrupt vector address symbol
         INTOPIN DAT
                          0005H
                                          ; definition
START:
                MAIN
         BR
ORG
         INTOPIN
           Processing A
                                          ; INTo pin interrupt processing
         ΕI
         RETI
TMRUP
                                          ; Timer carry processing
          Processing B
         RET
KEYDEC:
                                          ; Key input processing
          Processing C
         RET
MAIN:
                                          ; Sets key source output data (table reference)
         TVOM
                 DBF, @AR
                                          ; to key source data register (KSR)
         PUT
                 KSR, DBF
         SET2
                 KSEN, LCDEN
                                          ; Embedded macro
                                          ; Multiplexes LCD segment signal output with
                                          ; key source signal output
                                          ; Embedded macro
         SET2
                 BTM0CK1, BTM0CK0
                                          ; Sets timer carry FF setting time to 1 ms
                                          ; Software macro
         SET1_IP0
                                          ; Enables INTo pin interrupt
         ΕI
LOOP:
                 HLTINT OR HLTTMR OR HLTKEY
         HALT
                                          ; Specifies interrupt, timer carry, and key input
                                          ; as halt release conditions
                                          ; Embedded macro
         SKF1
                 BTM0CY
                                          ; Detects TMCY flag
                                          ; Timer carry processing if set to "1"
         CALL
                 TMRUP
                                          ; Embedded macro
         SKF1
                 KEYJ
                                          ; Detects key input latch
                                          ; Key input processing if latched
         CALL
                 KEYDEC
         BR
                 LOOP
```



In example 1 above, three halt release conditions are specified: INT<sub>0</sub> pin interrupt, 1-ms timer carry, and key input.

To detect which condition has caused the halt status to be released, the vector address, BTM0CY flag, and KEYJ flag are detected to identify the interrupt, timer carry, and key input, respectively.

When using two or more release conditions, the following two points must be noted.

- (1) All the specified release conditions must be detected when the halt status has been released.
- (2) The conditions must be sequentially detected starting from the one with the highest priority.

For example, if the program below "MAIN:" in example 1 above is as shown in example 2 below, care must be exercised. Do not develop the program as shown in example 2 if the timer carry has a high priority.

#### Example 2.

```
MAIN:
            P1C3, P1C2, P1C1, P1C0; Uses general-purpose output port as key
     SET4
                                       ; source signal
     SET2
            BTM0CK1, BTM0CK0
     ;
     SET1_IP0
     ΕI
 LOOP:
           HLTINT OR HLTTMR OR HLTKEY
     HALT
            POD3, POD2, POD1, POD0; Detects key input
     SKF4
     BR
            KEYDEC
     SKF1
            BTM0CY
     CALL
            TMRUP
     BR
            LOOP
 KEYDEC:
                                       ; Key input processing
       Processing C
     BR
            LOOP
```

In example 2 above, suppose the timer carry FF is set to "1" immediately after the halt status has been released by key input.

Then the program executes the "HALT" instruction again after executing the key input processing.

Because the timer carry FF remains set at this time, the halt status is immediately released.

Usually, however, a high level is input for about 100 ms as key input. Consequently, execution further branches to the key input processing.

As a result, the timer carry FF is not correctly detected.

## 12.5 Clock Stop Function

The clock stop function stops the 4.5-MHz crystal oscillation circuit by executing the "STOP s" instruction (clock stop status).

Therefore, the current consumption of the device is decreased to the minimum value of 15  $\mu$ A.

For the details on the current consumption, refer to 12.7 Current Consumption in Halt Status and Clock Stop Status.

Specify "0000B" as operand "s" of the "STOP s" instruction.

The "STOP s" instruction is valid only while the CE pin is low.

It is executed as a no-operation (NOP) instruction even when executed while the CE pin is high.

In other words, the "STOP s" instruction must be executed while the CE pin is low.

The clock stop status is released by raising the level of the CE pin from low to high (CE reset).

The following subsections 12.5.1 through 12.5.3 explain the clock stop status, how to release the clock stop status, and notes on using the clock stop instruction.

## 12.5.1 Clock stop status

Because the crystal oscillation circuit is stopped in the clock stop status, all the device operations, such as those of the CPU and peripheral hardware, are stopped.

For the operations of the CPU and peripheral hardware, refer to 12.6 Device Operations in Halt and Clock Stop Status.

The power failure detection circuit does not operate in the clock stop status even if the supply voltage V<sub>DD</sub> of the device is lowered to 2.2 V. Therefore, the data memory can be backed up at a low voltage. For the details on the power failure detection circuit, refer to **13. RESET**.

#### 12.5.2 Releasing clock stop status

The clock stop status is released either by raising the level of the CE pin from low to high (CE reset), or by lowering the supply voltage VDD of the device to 2.2 V or less once, and then increasing it to 4.5 V (power-ON reset).

Figures 12-4 and 12-5 respectively show how the clock stop is released on CE reset and power-ON reset.

If the clock stop status is released by power-ON reset, the power failure detection circuit operates.

For the details on power-ON reset, refer to 13.4 Power-ON Reset.



Figure 12-4. Releasing Clock Stop Status by CE Reset



Figure 12-5. Releasing Clock Stop Status by Power-ON reset





#### 12.5.3 Notes on using clock stop instruction

The clock stop (STOP s) instruction is valid only while the CE pin is low.

Therefore, processing to be performed if the CE pin happens to be high must be taken into consideration. Take the following program as an example.

## **Example**



In the above example, the status of the CE pin is detected in <1>. If the CE pin is low, processing A is performed and then the clock stop instruction "STOP XTAL" in <2> is executed.

If the CE pin goes high while the "STOP XTAL" instruction in <2> is executed, however, the "STOP XTAL" instruction is treated as a no-operation (NOP) instruction.

Should branch instruction "BR\$-1" in <3> be missing at this time, the program would execute the main processing, causing malfunctioning.

Therefore, either a branch instruction must be inserted as in <3>, or the program must be designed in the manner that malfunctioning does not occur even if the main processing is executed.

If a branch instruction is used as in <3>, CE reset is executed in synchronization with the next setting of the timer carry FF even while the CE pin is high.





## 12.6 Device Operations in Halt and Clock Stop Status

Table 12-1 shows the operations of the CPU and peripheral hardware in the halt status and clock stop status.

As shown in this table, all the peripheral hardware units continue the normal operation in the halt status, except that instruction execution is stopped.

All the peripheral hardware units stop operation in the clock stop status.

The control registers that control the operations of the peripheral hardware units operate normally in the halt status (i.e., are not initialized), but are initialized to specific values in the clock stop status (as soon as the STOP s instruction has been executed).

To put in another way, the peripheral hardware units continue the operations set by the control registers in the halt status, and operate in accordance with the control registers that are initialized to specific values in the clock stop status.

For the values to which the control registers are initialized, refer to 8. REGISTER FILE (RF).

Table 12-1. Device Operations in Halt Status and Clock Stop Status

| Peripheral Hardware               | Status                               |                                   |                                      |                                |
|-----------------------------------|--------------------------------------|-----------------------------------|--------------------------------------|--------------------------------|
|                                   | CE Pin = High                        |                                   | CE Pin = Low                         |                                |
|                                   | Halt                                 | Clock Stop                        | Halt                                 | Clock Stop                     |
| Program counter                   | Stops at address of HALT instruction | STOP instruction is invalid (NOP) | Stops at address of HALT instruction | Initialized to 0000H and stops |
| System register                   | Retained                             |                                   | Retained                             | Initialized <sup>Note</sup>    |
| Peripheral register               | Retained                             |                                   | Retained                             | Retained                       |
| Control register                  | Retained                             |                                   | Retained                             | Initialized <sup>Note</sup>    |
| Timer                             | Normal operation                     |                                   | Normal operation                     | Stops operation                |
| PLL frequency synthesizer         | Normal operation                     |                                   | Disabled                             | Disabled                       |
| A/D converter                     | Normal operation                     |                                   | Normal operation                     | Stops operation                |
| D/A converter                     | Normal operation                     |                                   | Normal operation                     | Stops operation                |
| BEEP output                       | Normal operation                     |                                   | Normal operation                     | Stops operation                |
| Serial interface                  | Normal operation                     |                                   | Normal operation                     | Stops operation                |
| Frequency counter                 | Normal operation                     |                                   | Normal operation                     | Stops operation                |
| LCD controller/driver             | Normal operation                     |                                   | Normal operation                     | Stops operation                |
| Key source controller/<br>decoder | Normal operation                     |                                   | Normal operation                     | Stops operation                |
| General-purpose I/O port          | Normal operation                     |                                   | Normal operation                     | Input port                     |
| General-purpose input port        | Normal operation                     |                                   | Normal operation                     | Input port                     |
| General-purpose output port       | Normal operation                     |                                   | Normal operation                     | Retained                       |

Note For the value to which these registers are initialized, refer to 5. SYSTEM REGISTER (SYSREG) and 8. REGISTER FILE (RF).

## 12.7 Current Consumption in Halt Status and Clock Stop Status

#### 12.7.1 Device current consumption in halt status

Figure 12-6 shows the device current consumption IDD in the halt status.

Current consumption curves <1> through <4> in this figure were drawn by using the programs shown below.

As shown in Figure 12-6, the less the halt status is released, the lower the current consumption.

## (1) Program 1

The HALT instruction is not used.

## Example

```
NOP
BR $ - 1
```

## (2) Program 2

A 5-ms timer interrupt is specified as the halt release condition, and 20 instructions (about 90  $\mu$ s) are executed each time the halt status has been released.

## Example

```
HLTINT
         DAT
               1000B
INTTM
               0003H
         DAT
               LOOP
         BR
ORG
         TMINT
REPT
         17
         NOP
ENDR
         ΕI
         RETI
LOOP:
         INITFLG BTM1CK1, NOT BTM1CK0
         SET_IPTM
         ΕI
         HALT HLTINT
               $ - 1
         BR
```



#### (3) Program 3

A 100-ms timer interrupt is specified as the halt release condition, and 20 instructions are executed each time the halt status has been released.

#### Example

```
HLTINT
         DAT
                1000B
INTTM
         DAT
                0003H
         BR
                LOOP
ORG
         TMINT
REPT
         17
         NOP
ENDR
         ΕI
         RETI
LOOP:
         CLR2
                BTM1CK1, BTM1CK0
         SET1_IPTM
         ΕI
         HALT HLTINT
         BR
                $ - 1
```

#### (4) Program 4

Nothing is set as the halt release condition.

#### Example

```
HLTNORLS DAT 0000B
HALT HLTNORLS
```

The device current consumption IDD shown in Figure 12-6 were measured under the following conditions.

- · PLL is disabled.
- · The frequency counter is disabled.
- A sine wave with a frequency fin = 4.5 MHz and input amplitude Vin = Vdd is input to the Xin pin from a standard signal generator.
- All the pins set in the output mode are open.
- All the pins set in the input mode are pulled down by a 47-kΩ resistor (except the X<sub>IN</sub> pin).

## 12.7.2 Device current consumption in clock stop status

Figure 12-7 shows the device current consumption IDD in the clock stop status.

The current consumption shown in this figure were measured under the following conditions.

- All the pins set in the output mode are open.
- All the pins set in the input mode are pulled down by a 47-k $\Omega$  resistor (except the XIN pin).
- A crystal resonator is connected (however, oscillation is stopped).

Figure 12-6. Device Current Consumption in Halt Status (Reference Value)





(b) IDD vs. TA (VDD = 5.5 V)



Figure 12-7. Device Current Consumption in Clock Stop Status (Reference Value)

(a) IDD vs. VDD (TA = 25 
$$^{\circ}$$
C)



(b) IDD vs. TA (VDD = 5.5 V)



## 12.7.3 Notes on processing each pin in halt and clock stop status

The halt status is used to reduce the current consumption, for example, when only the watch operates.

The clock stop function is used to reduce the current consumption when only the contents of the data memory are to be retained.

Therefore, the current consumption must be reduced as much as possible in the halt and clock stop statuses.

At this time, the current consumption may increase depending on the status of each pin, and therefore the points shown in Table 12-2 must be noted.



Table 12-2. Notes on Status of Each Pin in Halt and Clock Stop Statuses (1/2)

| Pin Function Pin Symbol            |         | Pin Symbol                                                                                                                                           | Status of Each Pin and Notes on Processing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                                    |         |                                                                                                                                                      | Halt Clock stop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| General-<br>purpose<br>port        | Port 0A | P0A <sub>3</sub> P0A <sub>2</sub> P0A <sub>1</sub> P0A <sub>0</sub>                                                                                  | Previous status before halt status is set is retained as is.  (1) In output mode  Current consumption increases  if the considerate process are status is input port mode.  All input ports, except port 0C (P0C <sub>3</sub> -P0C <sub>0</sub> ), are designed to prevent increases                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|                                    | Port 0B | P0B <sub>3</sub> P0B <sub>2</sub> /SCK P0B <sub>1</sub> /SO P0B <sub>0</sub> /SI                                                                     | if these pins are externally pulled down while they output high level, or externally pulled up while they output low level.  Pay attention to N-ch open-drain output pins (P0A <sub>3</sub> , P0A <sub>2</sub> , and low of the point of th |  |  |  |
|                                    | Port 0C | P0C <sub>3</sub> P0C <sub>2</sub> P0C <sub>1</sub> P0C <sub>0</sub>                                                                                  | P1B <sub>3</sub> -P1B <sub>0</sub> ).  (2) In input mode (except ports 1A and 1D)  Current consumption increases due to noise if these pins are                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|                                    | Port 1A | P1A <sub>3</sub><br>P1A <sub>2</sub><br>P1A <sub>1</sub><br>P1A <sub>0</sub>                                                                         | floated.  (3) Port 0D (P0D <sub>3</sub> /ADC <sub>5</sub> -P0D <sub>0</sub> /ADC <sub>2</sub> )  Current consumption increases if these pins are externally pulled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| General-<br>purpose<br>input port  | Port 0D | P0D <sub>3</sub> /ADC <sub>5</sub><br>P0D <sub>2</sub> /ADC <sub>4</sub><br>P0D <sub>1</sub> /ADC <sub>3</sub><br>P0D <sub>0</sub> /ADC <sub>2</sub> | up because they have pull-down resistor.  However, pull-down resistor of pin selected as A/D converter pin is OFF.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                                    | Port 1D | P1D <sub>3</sub> /FMIFC<br>P1D <sub>2</sub> /AMIFC<br>P1D <sub>1</sub> /ADC <sub>1</sub><br>P1D <sub>0</sub> /ADC <sub>0</sub>                       | (4) Ports 1D (P1D <sub>3</sub> /FMIFC-P1D <sub>0</sub> /ADC <sub>0</sub> ) and 1A (P1A <sub>3</sub> -P1A <sub>0</sub> )  Current consumption increases when P1D <sub>3</sub> /FMIFC and P1D <sub>2</sub> /AMIFC pins are used for IF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| General-<br>purpose<br>output port | Port 1B | P1B <sub>3</sub> P1B <sub>2</sub> /PWM <sub>1</sub> P1B <sub>1</sub> /PWM <sub>0</sub> P1B <sub>0</sub> /BEEP                                        | counter because internal amplifier operates.  Because IF counter is not automatically disabled even if CE pin goes low, it must be  These pins are set in general-purpose output port pins.  Output contents are retained as is.  Therefore, current consumption                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                                    | Port 1C | P1C <sub>3</sub> P1C <sub>2</sub> P1C <sub>1</sub> P1C <sub>0</sub>                                                                                  | initialized by program as necessary.  Ports 1D and 1A are designed to prevent increase in current consumption due to noise even if they are set in general purpose increases if these pins are externally pulled down while they output level, or pulled up while they output low level.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| Interrupt                          | Port 2A | P2A <sub>0</sub>                                                                                                                                     | input port mode and floated.  Current consumption increase due to external noise if this pin is floated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |



Table 12-2. Notes on Status of Each Pin in Halt and Clock Stop Statuses (2/2)

| Pin Function                 | Pin Symbol                                                                                                                                                                                                                                                        | Status of Each Pin and Notes on Processing                                                                                                                                                                                                                                                                                     |                                                                                                             |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|
|                              |                                                                                                                                                                                                                                                                   | Halt                                                                                                                                                                                                                                                                                                                           | Clock stop                                                                                                  |
| LCD segment                  | LCD <sub>29</sub> /P0F <sub>3</sub>   LCD <sub>26</sub> /P0F <sub>0</sub> LCD <sub>25</sub> /P0E <sub>3</sub>   LCD <sub>22</sub> /P0E <sub>0</sub> LCD <sub>21</sub>   LCD <sub>16</sub> LCD <sub>15</sub> /KS <sub>15</sub>   LCD <sub>0</sub> /KS <sub>0</sub> | Same as above general-purpose output ports applies if these pins are used in general-purpose output port mode.  If they output key source signals, current consumption increases via port 0D (with pull-down resistor) if there is switch that is always ON such as transistor switch and if "1" is output as key source data. | All pins are set in LCD segment signal output mode and output low level (display off).                      |
| PLL frequency<br>synthesizer | VCOL<br>VCOH<br>EO <sub>0</sub><br>EO <sub>1</sub>                                                                                                                                                                                                                | Current consumption increases during PLL operation.  These pins are as follows when PLL is disabled.  VCOL and VCOH : internally pulled down  EOo and EOo : floated  PLL is automatically disabled when CE pin goes low.                                                                                                       | PLL is disabled.  These pins are as follows.  VCOL and VCOH : internally pulled down  EOo and EOo : floated |
| Crystal oscillation circuit  | XIN<br>XOUT                                                                                                                                                                                                                                                       | Current consumption changes due to oscillation waveform of crystal oscillation circuit.  Current consumption decreases as oscillation amplitude increases.  Because oscillation amplitude is influenced by crystal resonator and load capacitor used, evaluation must be performed.                                            | X <sub>IN</sub> pin is internally pulled down, and X <sub>OUT</sub> pin outputs high level.                 |



#### 13. RESET

The reset function is used to initialize the device operation.

## 13.1 Configuration of Reset Block

Figure 13-1 shows the configuration of the reset block.

The device is reset in two ways: by applying supply voltage VDD (power-ON reset or VDD reset) and by using the CE pin (CE reset).

The power-ON reset block consists of a voltage detection circuit that detects a voltage input to the V<sub>DD</sub> pin, a power failure detection circuit, and a reset control circuit.

The CE reset block consists of a circuit that detects the rising of a signal input to the CE pin, and a reset control circuit.



Figure 13-1. Configuration of Reset Block

#### 13.2 Reset Function

Power-ON reset is effected when supply voltage V<sub>DD</sub> rises from a specific level, and CE reset is effected when the CE pin goes high.

Power-ON reset initializes the program counter, stack, system register, and control registers, and executes the program from address 0000H.

CE reset initializes the program counter, stack, system register, and some control registers, and executes the program from address 0000H.

The major differences between power-ON reset and CE reset are the control registers that are initialized and the operation of the power failure detection circuit that is explained in 13.6.

Both power-ON reset and CE reset are controlled by the reset signals  $\overline{\text{IRES}}$ ,  $\overline{\text{RES}}$ , and  $\overline{\text{RESET}}$  output from the reset control circuit shown in Figure 13-1.

Table 13-1 shows the relation among the IRES, RES, and RESET signals, and power-ON reset, and CE reset. The reset control circuit also operates when the clock stop instruction (STOP s) explained in **12. STANDBY** is executed.

The following sections 13.3 and 13.4 respectively explain CE reset and power-ON reset.

Section 13.5 explains the relation between CE reset and power-ON reset.

Table 13-1. Relation between Internal Reset Signals and Each Reset Operation

| Internal Reset Signal | Output Signal |                   |            | Control Operation by Each Reset Signal                                           |
|-----------------------|---------------|-------------------|------------|----------------------------------------------------------------------------------|
|                       | CE Reset      | Power-ON<br>Reset | Clock Stop |                                                                                  |
| ĪRES                  | ×             | 0                 | 0          | Forcibly sets device in halt status.                                             |
|                       |               |                   |            | Halt status is released when timer carry FF is set.                              |
| RES                   | ×             | 0                 | 0          | Initializes some control registers.                                              |
| RESET                 | 0             | 0                 | 0          | Initializes program counter, stack, system register, and some control registers. |



#### 13.3 CE Reset

CE reset is effected when the CE pin goes high.

When the CE pin goes high, the RESET signal is output in synchronization with the rising edge of the next timer carry FF setting pulse, and the device is reset.

When CE reset is effected, the RESET signal initializes the program counter, stack, system register, and some control registers, and the program is executed starting from address 0000H.

For the value to which each of the above registers is initialized, refer to the description of each register.

The operation of CE reset differs depending on whether the clock stop instruction is used.

The differences in operation are explained in the following subsections 13.3.1 and 13.3.2.

Subsection 13.3.3 explains the points to be noted on using CE reset.

## 13.3.1 CE reset when clock stop (STOP s) instruction is not used

Figure 13-2 shows the operation of CE reset when the clock stop (STOP s) instruction is not used.

When the STOP s instruction is not used, the timer mode select register of the control registers is not initialized.

After the CE pin has gone high, therefore, the RESET signal is output at the rising edge of the timer carry FF setting pulse (1 ms, 5 ms, 100 ms, 250 ms) selected at that time, and the device is reset.



Figure 13-2. CE Reset Operation When Clock Stop Instruction Is Not Used

this period "t" is  $0 < t < t_{\text{SET}}$  depending on timing of rising of CE pin. During this period, program continues its operation.

#### 13.3.2 CE reset when clock stop (STOP s) instruction is used

Figure 13-3 shows the operation of CE reset when the clock stop (STOP s) instruction is used.

When the STOP s instruction is used, the IRES, RES, and RESET signals are output as soon as the STOP s instruction has been executed.

At this time, the timer mode select register of the control registers is initialized to 0000B by the  $\overline{\text{RES}}$  signal, the timer carry FF setting signal is set to 100 ms.

Because the IRES signal is output while the CE pin is low, the halt status, which can be released by the timer carry, is forcibly set.

However, the device stops operation because the clock is stopped.

When the CE pin goes high, the clock stop status is released, and oscillation starts.

Because the halt status that can be released by the timer carry is set at this time by the IRES signal, the program starts from address 0 when the CE pin goes high and then the timer carry FF setting pulse rises.

Because the timer carry FF setting pulse is initialized to 100 ms, CE reset is effected 50 ms after the CE pin has gone high.



Figure 13-3. CE Reset Operation When Clock Stop Instruction Is Used



#### 13.3.3 Notes on CE reset

Because CE reset is effected regardless of the instruction under execution, the following points <1> and <2> must be noted.

## (1) Time to execute timer processing such as watch

When developing a watch program by using the timer carry or timer interrupt, the processing of that program must be completed in specific time.

For details, refer to 11.3.7 Notes on using timer carry and 11.4.5 Notes on using timer interrupt.

## (2) Processing of data and flag used for program

Care must be exercised in rewriting the contents of data or flag that cannot be processed with one instruction and whose contents must not change even when CE reset is effected, such as a security code. This is explained in detail by using the following examples.

## Example 1.

```
; First digit of key input data of security code
R 1
         MEM
                  0.01H
                                 ; Second digit of key input data of security code
                  0.02H
R2
         MEM
R3
         MEM
                  0.03H
                                ; First digit data for changing security code
                                ; Second digit data for changing security code
                  0.04H
R 4
         MEM
                                 ; First digit of current security code
         MEM
                  0.11H
M1
                  0.12H
                                ; Second digit of current security code
М2
         MEM
```

#### START:

```
Key input processing
    R1 ← contents of key A
                              ; Security code input wait mode
    R2 ← contents of key B
                              ; Substitutes contents of pressed key into R1 and R2.
               CMP, Z ;<1>; Compares security code with input data.
       SET2
       SUB
               R1, M1
       SUB
               R2, M2
                Ζ
       SKT1
       BR
                ERROR
                              ; Input data is different from security code.
MAIN:
```

# Key input processing

```
R3 ← contents of key C ; Security code rewriting mode ; Substitutes contents of pressed key into R3 and R4.
```

```
ST M1, R3 ;<2>; Rewrites security code. ST M2, R4 ;<3> MAIN
```

#### ERROR:

## Must not operate

Suppose the current security code is "12H" in the above program, the contents of data memory areas M1 and M2 are "1H" and "2H", respectively.

If CE reset is effected, the contents of key input are compared with security code "12H" in <1>. If they coincide, the normal processing is performed.

If the security code is changed by the main processing, the new code is written to M1 and M2 in <2> and <3>. Suppose the security code is changed to "34H", "3H" and "4H" are written to M1 and M2, respectively, in <2> and <3>.

If CE reset is effected at the point where <2> is executed, the program is executed from address 0000H without <3> executed.

Consequently, the security code is changed to "32H", making impossible to clear the security.

In this case, use the program shown in following Example 2.



#### Example 2.

```
; First digit of key input data of security code
R1
        MEM
                 0.01H
                                ; Second digit of key input data of security code
R2
                 0.02H
        MEM
R3
        MEM
                 0.03H
                                ; First digit data for changing security code
                                ; Second digit data for changing security code
                 0.04H
R4
        MEM
                 0.11H
                               ; First digit of current security code
M1
        MEM
                 0.12H
                                ; Second digit of current security code
М2
        MEM
                                ; "1" while security code is changed
CHANGE FLG
                 0.13H.0
START:
       Key input processing
      R1 \leftarrow contents of key A
                               ; Security code input wait mode
      R2 \leftarrow contents of key B
                               ; Substitutes contents of pressed key into R1 and R2.
                 CHANGE ;<4>; If CHANGE flag is "1"
        SKT1
        BR
                 SECURITY_CHK
                               ; rewrites M1 and M2.
        ST
                 M1, R3
        ST
                 M2, R4
        CLR1
                 CHANGE
SECURITY_CHK:
        SET2
                 CMP, Z;<1>; Compares security code with input data.
        SUB
                 R1, M1
                 R2, M2
        SUB
        SKT1
                 Ζ
                 ERROR
                                ; Input data is different from security code.
        BR
MAIN:
       Key input processing
      R3 \leftarrow contents of key C
                               ; Security code rewriting mode
      R4 ← contents of key D
                                ; Substitutes contents of pressed key into R3 and R4.
                 CHANGE ;<5>; Until security code is changed
         SET1
                                ; Sets CHANGE flag to "1".
                 M1, R3 ;<2>; Rewrites security code
        ST
         ST
                 M2, R4; <3>
                                ; When security code has been changed, sets
        CLR1
                 CHANGE
                                ; CHANGE flag to "0".
                 MAIN
         BR
```

Must not operate

ERROR:

In the program in Example 2, the CHANGE flag is set to "1" in <5> before the security code is changed in <2> and <3>.

Therefore, the security code is rewritten in <4> even if CE reset is effected before <3> is executed.

#### 13.4 Power-ON Reset

Power-ON reset is effected when the supply voltage VDD of the device rises from a specific level (called power-ON clear voltage).

If the supply voltage VDD is lower than the power-ON clear voltage, a power-ON clear signal (POC) is output from the voltage detection circuit shown in Figure 13-1.

When the power-ON clear voltage is output, the crystal oscillation circuit is stopped, and the device operation is stopped.

While the power-ON clear signal is output, the IRES, RES, and RESET signals are output.

If supply voltage V<sub>DD</sub> exceeds the power-ON clear voltage, the power-ON clear signal is cleared, and crystal oscillation is started. At the same time, the IRES, RES, and RESET signals are also cleared.

At this time, the halt status is set to be released by the timer carry due to the IRES signal. Therefore, power-ON reset is effected at the rising edge of the next timer carry FF setting signal.

The timer carry FF setting signal is initialized to 100 ms by the RESET signal. For this reason, reset is effected 50 ms after supply voltage VDD has exceeded the power-ON clear voltage, and the program is started from address 0.

This operation is illustrated in Figure 13-4.

The program counter, stack, system register, and control registers are initialized as soon as the power-ON clear signal has been output.

For the value to which each of the above registers is to be initialized, refer to the description of each register.

The power-ON clear voltage is 3.5 V (rated value) during normal operation, and 2.2 V (rated value) in the clock stop status.

The operations performed when the power-ON clear voltage is at the respective levels are explained in 13.4.1 and 13.4.2.

The operation to be performed if the supply voltage VDD rises from 0 V is explained in 13.4.3.



Figure 13-4. Operation of Power-ON Reset



#### 13.4.1 Power-ON reset during normal operation

Figure 13-5 (a) shows the operation.

As shown in the figure, the power-ON clear signal is output and the device operation stops regardless of the input level of the CE pin, if the supply voltage V<sub>DD</sub> drops below 3.5 V.

If VDD rises beyond 3.5 V again, the program starts from address 0000H after 50 ms of halt status.

The "normal operation" is when the clock stop instruction is not used and includes the halt status that is set by the halt instruction.

# 13.4.2 Power-ON reset in clock stop status

Figure 13-5 (b) shows the operation.

As shown in the figure, the power-ON clear signal is output and the device operation stops if supply voltage VDD drops below 2.2 V.

However, it seems as if the device operation were not changed because the device is in the clock stop status.

When supply voltage VDD rise beyond 3.5 V next time, the program starts from address 0000H after 50 ms of halt status.

#### 13.4.3 Power-ON reset when supply voltage VDD rises from 0 V

Figure 13-5 (c) shows the operation.

As shown in the figure, the power-ON clear signal is output until supply voltage  $V_{DD}$  rises from 0 V to 3.5 V.

When V<sub>DD</sub> rises beyond the power-ON clear voltage, the crystal oscillation circuit starts operating, and the program starts from address 0000H after 50 ms of halt status.



Figure 13-5. Power-ON Reset and Supply Voltage VDD

# (a) During normal operation (including halt status)



# (b) In clock stop status



# (c) When supply voltage VDD rises from 0 V





#### 13.5 Relation between CE Reset and Power-ON Reset

There is a possibility that power-ON reset and CE reset are effected at the same time when power is first applied.

The reset operations performed at this time are explained in 13.5.1 through 13.5.3.

13.5.4 explains the points to be noted in raising supply voltage VDD.

## 13.5.1 If VDD pin and CE pin rise simultaneously

Figure 13-6 (a) shows the operation.

At this time, the program starts from address 0000H due to power-ON reset.

## 13.5.2 If CE pin rises in forced halt status of power-ON reset

Figure 13-6 (b) shows the operation.

At this time, the program starts from address 0000H due to power-ON reset in the same manner as in 13.5.1.

# 13.5.3 If CE pin rises after power-ON reset

Figure 13-6 (c) shows the operation.

At this time, the program starts from address 0000H due to power-ON reset, and the program starts from address 0000H again at the rising of the next timer carry FF setting signal because of CE reset.

Figure 13-6. Relation between Power-ON Reset and CE Reset

# (a) If VDD and CE pins rise simultaneously



# (b) If CE pin rises in halt status



# (c) If CE pin rises after power-ON reset





#### 13.5.4 Notes on raising supply voltage VDD

When raising supply voltage VDD, keep in mind the following points (1) and (2).

## (1) When raising supply voltage VDD from power-ON clear voltage

It is necessary to raise supply voltage VDD to higher than 3.5 V at least once.

This is illustrated in Figure 13-7.

Suppose, for example, only a voltage less than 3.5 V is applied on application of V<sub>DD</sub> with a program that backs up V<sub>DD</sub> at 2.2 V by using the clock stop instruction, as shown in Figure 13-7, the power-ON clear signal is continuously output, and the program does not operate.

Because the output ports of the device output undefined values, the current consumption increases in some cases

If the device is backed up by batteries, therefore, the back-up time is substantially shortened.



Figure 13-7. Notes on Raising VDD

#### (2) Restoring from clock stop status

To restore the device from the back-up status while supply voltage V<sub>DD</sub> is backed up at 2.2 V by using the clock stop instruction, V<sub>DD</sub> must be raised to 3.5 V or higher within 50 ms after the CE pin has gone high.

As shown in Figure 13-8, the device is restored from the clock stop status by means of CE reset. Because the power-ON clear voltage is changed to 3.5 V 50 ms after the CE pin has gone high, power-ON reset is effected unless V<sub>DD</sub> is 3.5 V or higher at this point.

The same applies when VDD is lowered.



Figure 13-8. Restoring from Clock Stop Status



#### 13.6 Power Failure Detection

Power failure detection is used to judge whether power-ON reset by application of supply voltage V<sub>DD</sub>, or CE reset has been effected when the device is reset, as shown in Figure 13-9.

Because the contents of the data memory and ports are "undefined" on power application, these contents are initialized by means of power failure detection.

A power failure can be detected in two ways: by using the power failure detection circuit to detect the BTM0CY flag, and by detecting the contents of the data memory (RAM judgement).

13.6.1 and 13.6.2 explain how a power failure is detected by using the power failure detection circuit and BTM0CY flag.

13.6.3 and 13.6.4 explain how a power failure is detected by RAM judgement method.

Figure 13-9. Power Failure Detection Flow Chart



#### 13.6.1 Power failure detection circuit

The power failure detection circuit consists of a voltage detection circuit, a timer carry disable flip-flop that is set by the output (power-ON clear signal) of the voltage detection circuit, and a timer carry, as shown in Figure 13-1.

The timer carry disable FF is set to "1" by the power-ON clear signal, and is reset to "0" when an instruction that reads the BTM0CY flag is executed.

When the timer carry disable FF is set to "1", the BTM0CY flag is not set to "1".

When the power-ON clear signal is output (at power-ON reset), the program is started with the BTM0CY flag reset, and the BTM0CY flag is disabled from being set until an instruction that reads the BTM0CY flag is executed.

Once the instruction that reads the BTM0CY flag has been executed, the BTM0CY flag is set each time the timer carry FF setting pulses has risen. It can be judged whether power-ON reset (power failure) or CE reset (not power failure) has been effected by detecting the contents of the BTM0CY flag when the device is reset. Power-ON reset has been effected if the BTM0CY flag is reset to "0"; CE reset has been effected if it is set to "1".

The voltage at which a power failure can be detected is the same as the voltage at which power-ON reset is effected, or  $V_{DD} = 3.5 \text{ V}$  during crystal oscillation, or  $V_{DD} = 2.2 \text{ V}$  in the clock stop status.

Figure 13-10 shows the transition of the status of the BTM0CY flag.

Figures 13-11 and 13-10 show the timing chart and the operation of the BTM0CY flag.



Figure 13-10. Status Transition of BTM0CY Flag



Figure 13-11. Operation of BTM0CY Flag

# (a) When BTM0CY flag never detected (SKT1 BTM0CY or SKF1 BTM0CY is not executed)



# (b) When detecting power failure by BTM0CY flag



#### 13.6.2 Notes on detecting power failure by BTM0CY flag

The following points must be noted when using the BTM0CY flag for watch counting.

#### (1) Updating watch

When developing a watch program by using the timer carry, the watch must be updated after a power failure has been detected.

This is because counting of the watch is skipped once because the BTM0CY flag is reset to "0" when the BTM0CY flag is read on detection of a power failure.

#### (2) Watch updating processing time

The processing to update the watch must be completed before the next timer carry FF setting pulse rises. This is because, if the CE pin goes high during the watch updating processing, CE reset is effected without the watch updating processing completed.

For further information on (1) and (2) above, refer to 11.3.7 (b) Correction of timer carry on CE reset. When detecting a power failure, the following points must be noted.

#### (3) Timing of power failure detection

To count the watch by using the BTM0CY flag, the BTM0CY flag must be read to detect a power failure within the time since the program has started from address 0000H until the next timer carry FF setting pulse rises.

For example if the timer carry FF setting time is set to 5 ms, and a power failure is detected 6 ms after the program has been started, the BTM0CY flag is overlooked once.

For details, refer to 11.3.7 (b) Correction of timer carry on CE reset.

Power failure detection and initial processing must be completed within the timer carry FF setting time as shown in the following example.

This is because, if the CE pin goes high and CE reset is effected during power failure detection processing and initial processing, these processing may be stopped in midway, and thus problems may occur.

To change the timer carry FF setting time by the initial processing, the instruction that changes the time must be executed at the end of the initial processing, and the instruction must be one instruction.

This is because the initial processing may not be completely executed because of CE reset if the timer carry FF setting time is changed before the initial processing is executed, as shown in the following example.

## **Example**

START: ; Program address 0000H

;<1>

Processing on reset

;<2>

SKT1 BTM0CY ; Power failure detection

BR INITIAL

BACKUP: ;<3>

Watch updating

BR MAIN

INITIAL:

;<4>

Initial processing

;<5>

INITFLG BTM0CK1, NOT BTM0CK0 ; Embedded macro

; Sets timer carry FF setting time to 5 ms

MAIN:

Main processing

SKT1 BTM0CY
BR MAIN

Watch updating

BR MAIN



#### **Example of operation**



# 13.6.3 Power failure detection by RAM judgement method

The RAM judgement method is to detect a power failure by judging whether the contents of the data memory at a specific address are the specified value.

power failure processing < 4 > may not be

completely executed.

An example of a program that detects a power failure by the RAM judgement method is shown below.

The RAM judgement method detects a power failure by comparing an "undefined" value with the "specified value" because the contents of the data memory are "undefined" on application of supply voltage VDD.

Therefore, there is a possibility that a wrong judgment may be made as explained in 13.6.4 Notes on detecting power failure by RAM judgement method.

When the RAM judgement method is used, however, the device can be backed up at a voltage lower than that at which a power failure is detected, by using the power failure detection circuit, as shown in Table 13-2.

Table 13-2. Comparing Power Failure Detection by Power Failure Detection
Circuit and RAM Judgement Method

|                        | Power Failure De  | tection Circuit | RAM Judgement Method |             |  |
|------------------------|-------------------|-----------------|----------------------|-------------|--|
| Data hold voltage      | Effective value   | Rated value     | Effective value      | Rated value |  |
| (in clock stop status) | 1-2 V             | 2.2 V           | 0-1 V                | 2.0 V       |  |
| Operating status       | No malfunctioning |                 | Malfunctioning ma    | ay occur    |  |



## Example Program to detect power failure by RAM judgement method

```
M012
         MEM
                   0.12H
M034
         MEM
                   0.34H
M056
         MEM
                   0.56H
M107
                  1.07H
         MEM
M128
         MEM
                   1.28H
M16F
         MEM
                  1.6FH
DATA0
         DAT
                  1010B
DATA1
         DAT
                   0101B
DATA2
         DAT
                   0110B
DATA3
         DAT
                  1001B
DATA4
         DAT
                  1100B
DATA5
         DAT
                   0011B
START:
                  CMP, Z
         SET2
         SUB
                  M012, #DATA0
                                     ; If M012 = DATA0 and
                  M034, #DATA1
                                     ; M034 = DATA1 and
         SUB
                  M056, #DATA2
                                     ; M035 = DATA2 and
         SUB
         BANK1
                                     ; M107 = DATA3 and
         SUB
                  M107, #DATA3
                  M128, #DATA4
                                     ; M128 = DATA4 and
         SUB
                  M16F, #DATA5
                                     ; M16F = DATA5,
         SUB
         BANK 0
         SKF1
                   Z
         BR
                   BACKUP
                                     ; branches to BACKUP
 ; INITIAL:
```

# Initial processing

MOV M012, #DATA0
MOV M034, #DATA1
MOV M056, #DATA2
BANK1
MOV M107, #DATA3
MOV M128, #DATA4
MOV M16F, #DATA5
BR MAIN

Backup processing

MAIN:

BACKUP:

Main processing

#### 13.6.4 Notes on detecting power failure by RAM judgement method

The value of the data memory on application of supply voltage VDD is basically "undefined", and therefore, the following points (1) and (2) must be noted.

# (1) Data to be compared

Where the number of bits of the data memory to be compared by the RAM judgement method is "n bits", the probability at which the value of the data memory coincides with the value to be compared on application of  $V_{DD}$  is  $(1/2)^n$ .

This means that backup is judged at a probability of  $(1/2)^n$  when a power failure is detected by the RAM judgement method.

To lower this probability, as many bits as possible must be compared.

Because the contents of the data memory on application of V<sub>DD</sub> are likely to be the same value such as "0000B" and "1111B", it is recommended to mix "0" and "1" as data to be compared, such a "1010B" and "0110B" to reduce the possibility of a wrong judgment.

## (2) Notes on program

If V<sub>DD</sub> rises from the level at which the data memory contents may be destroyed as shown in Figure 13-12, and even if the value of the data memory area to be compared is normal, the values of the other data memory areas may be destroyed.

This is judged as backup if a power failure is detected by the RAM judgement method. Therefore, consideration must be given so that the program does not hang up even if the contents of the data memory are destroyed.

Data memory destruction start voltage

Figure 13-12. VDD and Destruction of Data Memory Contents

Values of data memory areas not used for RAM judgement may be destroyed.

Data memory for RAM judgement (normal)



#### 14. PLL FREQUENCY SYNTHESIZER

The PLL (Phase Locked Loop) frequency synthesizer is used to lock the frequency in the MF (Medium Frequency), HF (High Frequency), and VHF (Very High Frequency) bands to a specific frequency by comparing phase differences.

# 14.1 Configuration of PLL Frequency Synthesizer

Figure 14-1 shows the block diagram of the PLL frequency synthesizer.

As shown in the figure, the PLL frequency synthesizer consists of an input select block, programmable divider (PD), phase comparator ( $\phi$ -DET), reference frequency generator (RFG), and charge pump.

By connecting these blocks with an external lowpass filter (LPF) and voltage-controlled oscillator (VCO), a PLL frequency synthesizer is organized.



Figure 14-1. Block Diagram of PLL Frequency Synthesizer

Note External circuit



# 14.2 Functional Outline of PLL Frequency Synthesizer

The PLL frequency synthesizer divides a signal input from the VCOH (pin 32) or VCOL (pin 31) pin by using the programmable divider and outputs a phase difference from the reference frequency from the EO<sub>1</sub> and EO<sub>0</sub> pins.

The PLL frequency synthesizer operates only when the CE pin is high, and is disabled when the CE pin is low.

For the details on the disable status of the PLL frequency synthesizer, refer to 14.6.

The following subsections 14.2.1 through 14.2.6 outline the function of each block of the PLL frequency synthesizer.

#### 14.2.1 Input select block

This block selects the pin from which a signal output from an external voltage-controlled oscillator is input. As the input pin, the VCOH or VCOL pin is selected by the PLL mode select register (RF address 21H). For details, refer to 14.3.

#### 14.2.2 Programmable divider

The programmable divider divides the signal input from the VCOH or VCOL pin at the division ratio set by the program.

Two types of division modes can be selected: direct division and pulse swallow modes.

The division mode is selected by the PLL mode select register.

The division ratio is set by the PLL data register (PLLR: peripheral address 41H) via the data buffer.

For details, refer to 14.3.

## 14.2.3 Reference frequency generator

This generator generates a reference frequency to be compared by the phase comparator.

Twelve types of reference frequencies can be selected by using the PLL reference mode select register (RF address 31H).

For details, refer to 14.4.

#### 14.2.4 Phase comparator and unlock detection block

The phase comparator compares the division signal output by the programmable divider with the signal from the reference frequency generator, and outputs a phase difference.

The unlock detection block detects the unlock status of the PLL.

The unlock status of the PLL is detected by the PLL unlock FF judge register (RF address 05H).

For details, refer to 14.5.

#### 14.2.5 Charge pump

The charge pump outputs the signal output by the phase comparator to the EO<sub>1</sub> an EO<sub>0</sub> pins as a high-level, low-level, or floating signal.

For details, refer to 14.5.



# 14.3 Input Select Block and Programmable Divider

# 14.3.1 Configuration of input select block and programmable divider

Figure 14-2 shows the configuration of the input select block and programmable divider.

As shown in the figure, the input select block consists of the VCOH and VCOL pins, and the amplifiers of the respective pins.

The programmable divider consists of a 2-modulus prescaler, swallow counter, programmable counter, and division mode select switch.

Figure 14-2. Configuration of Input Select Block and Programmable Divider

Control register Data buffer (DBF) Address Address 0CH 21H 0DH 0EH Bit  $b_2$ b<sub>1</sub>  $b_0$ Symbol DBF3 DBF2 DBF1 bз

0FH DBF0 Flag Data M S B L S L symbol L В М Μ Μ М D 3 D 2 D D 16 Peripheral address 41H PLL data register 2-4 decoder 12 bits 4 bits 12 PSC MF VHF 2-modulus Swallow prescaler counter 4 bits 1/16, 1/17 VHF HF Programmable To φ-DET counter 12 bits  $\overline{\mathsf{MF}}$ HF PLL disable signal



#### 14.3.2 Functions of input select block and programmable divider

The input select block and programmable divider selects the input pin and division mode of the PLL frequency synthesizer.

As the input pin, the VCOH or VCOL pin can be selected.

The selected pin goes into an intermediate-potential state (approx. 1/2 VDD). The pin not selected is internally pulled down.

These pins input signals via an AC amplifier, and the DC component of the input signal must be cut off by connecting a capacitor to the pin in series.

Either the direct division mode or pulse swallow mode can be selected as the division mode.

The programmable counter divides the signal input from the VCOH or VCOL pin in a specified division mode according to the values set to the swallow counter and programmable counter.

Table 14-1 show the input pins (VCOH and VCOL) and division modes.

The input pin and division mode to be used are selected by the PLL mode select register.

14.3.3 explains the configuration and function of the PLL mode select register.

The division ratio is set to the programmable divider by the PLL data register via the data buffer.

14.3.4 explains the programmable divider and PLL data register.

Table 14-1. Input Pins and Division Modes

| Division Mode         | Pin  | Input Frequency<br>(MHz) | Input Amplitude<br>(V <sub>P-P</sub> ) | Settable Division<br>Ratio | Division Ratio Settable in<br>Data Buffer           |
|-----------------------|------|--------------------------|----------------------------------------|----------------------------|-----------------------------------------------------|
| Direct division (MF)  | VCOL | 0.5-30                   | 0.2                                    | 16 to 2 <sup>12</sup> – 1  | 010×H-FFF×H<br>(x: low-order 4 bits are don't care) |
| Pulse swallow<br>(HF) | VCOL | 5-40                     | 0.2                                    | 256 to 2 <sup>16</sup> – 1 | 0100H-FFFFH                                         |
| Pulse swallow (VHF)   | VCOH | 9-150                    | 0.2                                    | 256 to 2 <sup>16</sup> – 1 | 0100H-FFFFH                                         |



#### 14.3.3 Configuration and function of PLL mode select register

The PLL mode select register specifies the division mode of the PLL frequency synthesizer and the pin to be used.

The configuration and function of the PLL mode select register are shown below.

The paragraphs (1) through (4) below outlines the respective division modes.



# CE | Re

## (1) Direct division mode (MF)

In this mode, the VCOL pin is used.

The VCOH pin is pulled down.

In the direct division mode, the frequency of the input signal is divided only by the programmable counter.

# (2) Pulse swallow mode (HF)

The VOL pin is used in this mode.

The VCOH pin is pulled down.

In this mode, the frequency of the input signal is divided by the swallow counter and programmable counter.

# (3) Pulse swallow mode (VHF)

The VCOH pin is used in this mode.

The VCOL pin is pulled down.

In this mode, the frequency of the input signal is divided by the swallow counter and programmable counter.

# (4) Disabling VCOL and VCOH pins

The VCOH and VCOL pins are internally pulled down.

However, the phase comparator, reference frequency generator, and charge pump operate.

Therefore, the operation is different from that in the PLL disable status to be explained later.

#### 14.3.4 Programmable divider and PLL data register

The programmable divider divides the signal input from the VCOH or VCOL pin by the value set to the swallow counter and programmable counter.

The swallow counter and programmable counter are 4-bit binary down counters.

The division ratio is set to the swallow counter and programmable counter by the PLL data register (PLLR: peripheral address 41H) via data buffer.

Data is set to or read from the PLL data register by using the "PUT PLLR, DBF" or "GET DBF, PLLR" instruction.

The value to be divided is called N value.

For how to set the N value in each division mode, refer to 14.7.

# (1) PLL data register and data buffer

The relation between the PLL data register and data buffer is explained next.

In the direct division mode, the high-order 12 bits are valid, and all the 16 bit are valid in the pulse swallow mode.

In the direct division mode, all the high-order 12 bits are set to the programmable counter.

In the pulse swallow mode, the high-order 12 bits are set to the programmable counter, and the low-order 4 bits are set to the swallow counter.

# (2) Relation between division value N and divided output frequency

The relation between the value "N" set to the PLL data register and the frequency "fn" of the signal divided and output by the programmable divider is as follows.

For details, refer to 14.7.

(a) In direct division mode (MF)

$$f_N = \frac{f_{IN}}{N}$$
 N: 12 bits

(b) In pulse swallow mode (HF and VHF)

$$f_N = \frac{f_{IN}}{N}$$
 N: 16 bits





# 14.4 Reference Frequency Generator

# 14.4.1 Configuration and function of reference frequency generator

Figure 14-3 shows the configuration of the reference frequency generator.

As shown in the figure, the reference frequency generator divides 4.5 MHz of the crystal oscillation circuit to generate the reference frequency "fr" of the PLL frequency synthesizer.

Twelve reference frequencies can be selected: 1, 1.25, 2.5, 3, 5, 6.25, 9, 10, 12.5, 25, 50, and 100 kHz. Reference frequency fr is selected by the PLL reference mode select register.

14.4.2 shows the configuration and function of the PLL reference mode select register.

Figure 14-3. Configuration of Reference Frequency Generator (RFG)





# 14.4.2 Configuration and function of PLL reference mode select register

The configuration and function of the PLL reference mode select register are shown below.

| Name                               | F                               | lag s          | ymb                        | ol                         | Address     | Read/       |                                           |
|------------------------------------|---------------------------------|----------------|----------------------------|----------------------------|-------------|-------------|-------------------------------------------|
|                                    | bз                              | b <sub>2</sub> | b <sub>1</sub>             | bo                         |             | Write       |                                           |
| PLL reference mode select register | P<br>L<br>R<br>F<br>C<br>K<br>3 | C              | P<br>L<br>R<br>F<br>C<br>K | P<br>L<br>R<br>F<br>C<br>K | 31H         | R/W         |                                           |
|                                    |                                 |                |                            |                            |             |             | _                                         |
|                                    |                                 |                |                            | -                          | Sets        | reference f | frequency fr of PLL frequency synthesizer |
|                                    | 0                               | 0              | 0                          | 0                          | 1.25 kHz    |             |                                           |
|                                    | 0                               | 0              | 0                          | 1                          | 2.5 kHz     |             |                                           |
|                                    | 0                               | 0              | 1                          | 0                          | 5 kHz       |             |                                           |
|                                    | 0                               | 0              | 1                          | 1                          | 10 kHz      |             |                                           |
|                                    | 0                               | 1              | 0                          | 0                          | 6.25 kHz    |             |                                           |
|                                    | 0                               | 1              | 0                          | 1                          | 12.5 kHz    |             |                                           |
|                                    | 0                               | 1              | 1                          | 0                          | 25 kHz      |             |                                           |
|                                    | 0                               | 1              | 1                          | 1                          | 50 kHz      |             |                                           |
|                                    | 1                               | 0              | 0                          | 0                          | 3 kHz       |             |                                           |
|                                    | 1                               | 0              | 0                          | 1                          | Setting pro | hibited     |                                           |
|                                    | 1                               | 0              | 1                          | 0                          | Setting pro | hibited     |                                           |
|                                    | 1                               | 0              | 1                          | 1                          | Setting pro | hibited     |                                           |
|                                    | 1                               | 1              | 0                          | 0                          | 1 kHz       |             |                                           |
|                                    | 1                               | 1              | 0                          | 1                          | 9 kHz       |             |                                           |

| #     | Power-ON   | 1 | 1    | 1    | 1 |
|-------|------------|---|------|------|---|
| reset | Clock stop | 1 | 1    | 1    | 1 |
| ŏ     | CE         |   | Reta | ined |   |

When the PLL is disabled by the PLL reference mode select register, the VCOH and VCOL pins are internally pulled down.

100 kHz

PLL disabled

1 1

1 | 1 | 1 | 1

The EO<sub>1</sub> and EO<sub>0</sub> pins are floated.

For disabling the PLL, refer to 14.6.

# 14.5 Phase Comparator ( $\phi$ -DET), Charge Pump, and Unlock Detection Block

## 14.5.1 Configuration of phase comparator, charge pump, and unlock detection block

Figure 14-4 shows the configuration of the phase comparator, charge pump, and unlock detection block.

The phase comparator compares the divided frequency output " $f_N$ " of the programmable divider with the reference frequency output " $f_r$ " of the reference frequency generator, and outputs an up request  $(\overline{UP})$  or down request  $(\overline{DW})$  signal.

The charge pump outputs the output of the phase comparator from the error out (EO<sub>1</sub> and EO<sub>0</sub>) pins.

The unlock detection block detects the unlock status of the PLL frequency synthesizer.

The following subsections 14.5.2 through 14.5.4 respectively explain the operations of the phase comparator, charge pump, and unlock detection block.

Figure 14-4. Configuration of Phase Comparator, Charge Pump, and Unlock Detection Block





#### 14.5.2 Function of phase comparator

As shown in Figure 14-4, the phase comparator compares the divided frequency output "f<sub>N</sub>" of the programmable divider with the reference frequency output "f<sub>r</sub>" of the reference frequency generator, and outputs an up request or down request signal.

If the divided frequency  $f_N$  is lower than the reference frequency  $f_r$ , the phase comparator outputs the up request signal; if  $f_N$  is higher than  $f_r$ , it outputs the down request signal.

Figure 14-5 shows the relation among the reference frequency  $f_r$ , divided frequency  $f_N$ , up request signal, and down request signal.

When the PLL is disabled, neither the up request nor down request signal is output.

The up request and down request signals are respectively input to the charge pump and unlock detection

Figure 14-5. Relation among  $f_r$ ,  $f_N$ ,  $\overline{UP}$ , and  $\overline{DW}$ 

# (a) If fN is behind fr in phase



# (b) If fn leads fr in phase



## (c) If fn and fr are in phase



# (d) If fn is lower than fr in frequency



# 14.5.3 Charge pump

As shown in Figure 14-4, the charge pump outputs the up request signal or down request signal from the phase comparator to the error out (EO<sub>1</sub> and EO<sub>0</sub>) pins.

Therefore, the relation among the outputs of the error out pins, divided frequency  $f_N$ , and reference frequency  $f_T$  are as follows.

When reference frequency  $f_r >$  divided frequency  $f_N$ : low-level output When reference frequency  $f_r <$  divided frequency  $f_N$ : high-level output When reference frequency  $f_r =$  divided frequency  $f_N$ : floating output



#### 14.5.4 Unlock detection block

As shown in Figure 14-4, the unlock detection block detects the unlock status of the PLL frequency synthesizer by using the up request or down request signal from the phase comparator.

Because either of the up request or down request signal outputs a low level in the unlock status, this low-level signal is used to detect the unlock status.

In the unlock status, the unlock flip-flop (FF) is set to 1.

The unlock status is detected by the PLL unlock FF judgement register (refer to 14.5.5).

The unlock FF is set at the cycle of reference frequency fr selected at that time.

When the contents of the PLL unlock FF judgement register are read (by the PEEK instruction), the unlock FF is reset (Read & Reset).

Therefore, the unlock FF must be detected at a cycle longer than the cycle 1/fr of the reference frequency fr.

#### 14.5.5 Configuration and function of unlock FF judgement register



This register is a read-only register and is reset when its contents are read to the window register by the "PEEK" instruction.

Because the unlock FF is set at the cycle of reference frequency fr, the contents of the PLL unlock FF judgement register must be written to the window register at a cycle longer than the cycle 1/fr of the reference frequency fr.



#### 14.6 PLL Disabled Status

The PLL frequency synthesizer stops operation (is disabled) while the CE pin (pin 13) is low.

When the PLL is disabled by the PLL reference mode select register, the PLL frequency synthesizer also stops operation.

Table 14-2 shows the operation of each block under each PLL disable condition.

When the VCOL and VCOH pins are disabled by the PLL mode select register, only the VCOL and VCOH pins are internally pulled down, and the other blocks operate.

Because the PLL reference mode select register and PLL mode select register are not initialized (but hold the previous status) on CE reset, they are restored to the original status when the CE pin has once gone low and then back high again after the PLL has been disabled.

To disable the PLL on CE reset, therefore, initialize these registers in the program.

The PLL is disabled at power-ON reset.

Table 14-2. Operation of Blocks Under PLL Disable Conditions

| Condition                     | CE Pin = Low Level     | CE Pin = Hig                                              | jh Level                                                                |
|-------------------------------|------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------|
| Blocks                        | (PLL disabled)         | PLL reference mode select register = 1111B (PLL disabled) | PLL mode select register = 0000B (VCOH, VCOL disabled)                  |
| VCOL and VCOH pins            | Internally pulled down | Internally pulled down                                    | Internally pulled down                                                  |
| Programmable counter          | Stops division         | Stops division                                            | Operates                                                                |
| Reference frequency generator | Stops output           | Stops output                                              | Operates                                                                |
| Phase comparator              | Stops output           | Stops output                                              | Operates                                                                |
| Charge pump                   | Floats error out pins  | Floats error out pins                                     | Operates. However, usually outputs low level because there is no input. |

#### 14.7 Using PLL Frequency Synthesizer

To control the PLL frequency synthesizer, the following data are necessary.

(1) Division mode : direct division (MF), pulse swallow (HF, VHF)

(2) Pin used : VCOL, VCOH

(3) Reference frequency: fr(4) Division ratio : N

The following subsections 14.7.1 through 14.7.3 explain how to set the PLL data in each division mode (MF, HF, and VHF).



#### 14.7.1 Direct division mode

# (1) Selecting division mode

Select the direct division mode by using the PLL mode select register.

#### (2) Pin used

When the direct division mode is selected, the VCOL pin is enabled to operate.

# (3) Setting reference frequency fr

Set the reference frequency by using the PLL reference mode select register.

# (4) Calculating division value N

Calculate as follows:

$$N = \frac{f_{VCOL}}{f_r}$$

where,

fvcol: input frequency of VCOL pin

fr : reference frequency

# (5) Example of setting PLL data

How to set the data to receive broadcasting in the following MW band is explained below.

Reception frequency : 1422 kHz (MW band)

Reference frequency : 9 kHz Intermediate frequency: +450 kHz

Division value N:

$$N = \frac{f_{VCOL}}{f_r} = \frac{1422 + 450}{9} = 208 \text{ (decimal)}$$
$$= 0D0H \text{ (hexadecimal)}$$

Set data to the PLL data register (PLLR: peripheral address 41H), PLL mode select register (RF address 21H), and PLL reference mode select register (RF address 31H) as follows.



|   | PLL mode<br>select register |   |   |   |     | PLL reference<br>mode select<br>register |   |  |  |
|---|-----------------------------|---|---|---|-----|------------------------------------------|---|--|--|
| 0 | 0                           | 0 | 1 | 1 | 1   | 0                                        | 1 |  |  |
|   | М                           | F |   |   | 9 I | кНz                                      |   |  |  |



#### 14.7.2 Pulse swallow mode (HF)

# (1) Selecting division mode

Select the pulse swallow mode by using the PLL mode select register.

## (2) Pin used

When the pulse swallow mode is selected, the VCOL pin is enabled to operate.

# (3) Setting reference frequency fr

Set the reference frequency by using the PLL reference mode select register.

# (4) Calculating division value N

Calculate as follows:

$$N = \frac{f_{VCOL}}{f_r}$$

where,

fvcol: input frequency of VCOL pin

fr : reference frequency

# (5) Example of setting PLL data

How to set the data to receive broadcasting in the following SW band is explained below.

Reception frequency : 25.50 MHz (SW band)

Reference frequency : 5 kHz Intermediate frequency: +450 kHz

Division value N:

$$N = \frac{f_{VCOL}}{f_r} = \frac{25500 + 450}{5} = 5190 \text{ (decimal)}$$
$$= 1446 \text{H (hexadecimal)}$$

Set data to the PLL data register (PLLR: peripheral address 41H), PLL mode select register (RF address 21H), and PLL reference mode select register (RF address 31H) as follows.



| PLL mode<br>select register |   |    |   | PLL reference<br>mode select<br>register |     |    |   |
|-----------------------------|---|----|---|------------------------------------------|-----|----|---|
| 0                           | 0 | 1  | 1 | 0                                        | 0   | 1  | 0 |
|                             | F | IF |   |                                          | 5 k | Hz |   |



#### 14.7.3 Pulse swallow mode (VHF)

# (1) Selecting division mode

Select the pulse swallow mode by using the PLL mode select register.

## (2) Pin used

When the pulse swallow mode is selected, the VCOH pin is enabled to operate.

# (3) Setting reference frequency fr

Set the reference frequency by using the PLL reference mode select register.

# (4) Calculating division value N

Calculate as follows:

$$N = \frac{f_{VCOH}}{f_r}$$

where,

fvcoн: input frequency of VCOH pin

fr : reference frequency

# (5) Example of setting PLL data

How to set the data to receive broadcasting in the following FM band is explained below.

Reception frequency : 100.0 MHz (FM band)

Reference frequency : 25 kHz Intermediate frequency: +10.7 MHz

Division value N:

$$N = \frac{f_{VCOH}}{f_r} = \frac{100.0 + 10.7}{0.025} = 4428 \text{ (decimal)}$$
  
= 114CH (hexadecimal)

Set data to the PLL data register (PLLR: peripheral address 41H), PLL mode select register (RF address 21H), and PLL reference mode select register (RF address 31H) as follows.



|   | L m<br>ect |    | ster | PLL reference<br>mode select<br>register |    |     |   |
|---|------------|----|------|------------------------------------------|----|-----|---|
| 0 | 0          | 1  | 0    | 0                                        | 1  | 1   | 0 |
|   | VI         | HF |      |                                          | 25 | kHz |   |



#### 14.8 Status on Reset

# 14.8.1 On power-ON reset

The PLL is disabled on power-ON reset because the PLL reference mode select register is initialized to 1111B.

# 14.8.2 On execution of clock stop instruction

The PLL is disabled when the CE pin goes low.

## 14.8.3 On CE reset

# (1) CE reset after execution of clock stop instruction

The PLL is disabled because the PLL reference mode select register is initialized to 1111B by the clock stop instruction.

# (2) CE reset without clock stop instruction executed

Because the PLL reference mode select register retains the previous status, the previous status is restored as soon as the CE pin has gone high.

## 14.8.4 In halt status

The set status is retained if the CE pin is high.

175



#### 15. GENERAL-PURPOSE PORT

The general-purpose ports output a high-level, low-level, or floating signal to an external circuit, and read a high-level or low-level signal from the external circuit.

# 15.1 Configuration and Classification of General-Purpose Ports

Figure 15-1 shows the block diagram of the general-purpose ports.

Table 15-1 classifies the general-purpose ports.

As shown in Figure 15-1, the general-purpose ports include ports 0A (P0A) through 2A (P2A) to which are set by addresses 70H through 73H (port registers) of each bank of the data memory, and ports 0E (P0E) and 0F (P0F) to which data are set by addresses 6BH and 6DH of bank 0 of the data memory.

Each port consists of general-purpose port pins (e.g., port 0A consists of P0A3 through P0A0 pins).

As shown in Table 15-1, the general-purpose ports are classified into input/output ports (I/O ports), input-only ports (input ports), and output-only ports (output ports).

The I/O ports are further subdivided into bit I/O ports that can be set in the input or output mode in 1-bit units (1-pin units) and group I/O ports that can be set in the input or output mode in 4-bit units (4-pin units).



Figure 15-1. Block Diagram of General-Purpose Port

**Note** BANK3 is not provided on the  $\mu$ PD17016.



Table 15-1. Classification of General-Purpose Ports

| Classification of G   | Classification of General-Purpose Ports |           |                               | Data Set by:                                          |
|-----------------------|-----------------------------------------|-----------|-------------------------------|-------------------------------------------------------|
| General-purpose ports | I/O ports                               | Bit I/O   | Port 0A<br>Port 0B<br>Port 0C | Port register                                         |
|                       |                                         | Group I/O | Port 0C                       | Port register                                         |
|                       | Input port                              |           | Port 0D<br>Port 1D            | Port register                                         |
|                       | Output port                             |           | Port 1B<br>Port 1C<br>Port 2A | Port register                                         |
|                       |                                         |           | Port 0E<br>Port 0F            | Port register (multiplexed with LCD segment register) |

# 15.2 Functional Outline of General-Purpose Ports

The general-purpose output ports and the general-purpose I/O ports set in the output mode output a high or low level from the corresponding pins when data are set to the corresponding port register or port group register.

The general-purpose input ports and the general-purpose I/O ports set in the input mode detect the level of the signals input to the corresponding pins by reading the contents of the corresponding port register.

The general-purpose I/O ports are set in the input or output mode by the corresponding control register.

In other words, these ports can be set in the input or output mode by program.

P0A through P0D, P1A through P1D, and P2A are set in the general-purpose port mode on power-ON reset.

P0E and P0F are used as LCD segment signal output pins on power-ON reset. To use these ports as general-purpose output ports, the corresponding control registers must be set independently.

The following subsections 15.2.1 through 15.2.4 explain the port registers, the function of the port group register, and the functional outline of each port.

#### 15.2.1 General-purpose port data register (port register)

A port register sets output data of and reads the input data of the corresponding general-purpose port.

Because the port registers are mapped on the data memory, they can be manipulated by any data memory manipulation instruction.

Figure 15-2 shows the relation between a port register and the corresponding port pins.

By setting data to the port register corresponding to the port pins set in the general-purpose output port mode, the output of each pin is set.

By reading the contents of the port register corresponding to the port pins set in the general-purpose input port mode, the input status of each pin is detected.

Table 15-2 shows the relation between each port (each pin) and port register.

Figure 15-2. Relation between Port Register and Pins



Reserved words are defined for the port registers by the assembler.

Because these reserved words are defined in flag (bit) units, the assembler embedded macro instructions can be used.

Note that data memory type reserved words are not defined for the port registers.

P0E and P0F are multiplexed with LCD segment signal output pins. The port registers of P0E and P0F are also multiplexed with LCD segment registers.

Because the LCD segment registers are also mapped on the data memory, they can be treated in the same manner as the port registers.



#### 15.2.2 General-purpose I/O ports (P0A, P0B, P0C, and P1A)

P0A, P0B, P0C, and P1A can be set in the input or output mode by the P0A bit I/O select register (RF address 37H), P0B bit I/O select register (RF address 36H), P0C group I/O select register (RF address 27H), P1A bit I/O select register (RF address 35H), respectively.

The input/output data of the P0A, P0B, P0C, and P1A are set by port registers P0A (address 70H of BANK0), P0B (address 71H of BANK0), P0C (address 72H of BANK0), and P1A (address 70H of BANK1), respectively.

Refer to Table 15-2.

For details, refer to 15.3.

#### 15.2.3 General-purpose input ports (P0D and P1D)

The input data of P0D and P1D are read by port registers P0D (address 73H of BANK0) and P1D (address 73H of BANK1), respectively.

Refer to Table 15-2.

For details, refer to 15.4.

### 15.2.4 General-purpose output ports (P1B, P1C, P2A, P0E, and P0F)

### (1) P1B, P1C, and P2A

The output data of P1B, P1C, and P2A are set by port registers P1B (address 71H of BANK1), P1C (address 72H of BANK1), and P2A (address 70H of BANK2).

Refer to Table 15-2.

For details, refer to 15.5.

### (2) P0E and P0F

P0E and P0F usually operate as LCD segment signal output pins. These ports can be set in the output port mode by using a software macro supplied with the device file.

To set the output data of P0E and P0F, P0E register (multiplexed with LCD segment register LCDD13, address 6DH of BANK0) and P0F register (multiplexed with LCDD11, address 6BH of BANK0) are used, respectively. Refer to **Table 15-2**.

For details, refer to 15.6.



Table 15-2. Relation between Each Port (Pin) and Port Register (1/2)

| Port    |                | Pin              |           |       |             | Settin | g of Data           |                        |
|---------|----------------|------------------|-----------|-------|-------------|--------|---------------------|------------------------|
|         | No.            | Symbol           | I/O       |       | Port regist | Remark |                     |                        |
|         |                |                  |           | Bank  | Address     | Symbol | Bit symbol          |                        |
|         |                |                  |           |       |             |        | (reserved word)     |                        |
| Port 0A | 3              | P0A <sub>3</sub> | I/O       | BANK0 | 70H         | P0A    | b <sub>3</sub> P0A3 |                        |
| (P0A)   | 4              | P0A <sub>2</sub> | (bit I/O) |       |             |        | b <sub>2</sub> P0A2 |                        |
|         | 5              | P0A <sub>1</sub> |           |       |             |        | b <sub>1</sub> P0A1 |                        |
|         | 6              | P0A <sub>0</sub> |           |       |             |        | bo P0A0             |                        |
| Port 0B | 7              | P0B₃             | I/O       |       | 71H         | P0B    | b₃ P0B3             |                        |
| (P0B)   | 8              | P0B <sub>2</sub> | (bit I/O) |       |             |        | b <sub>2</sub> P0B2 |                        |
|         | 9              | P0B <sub>1</sub> |           |       |             |        | b <sub>1</sub> P0B1 |                        |
|         | 10             | P0B₀             |           |       |             |        | bo P0B0             |                        |
| Port 0C | 79             | P0C₃             | I/O       |       | 72H         | P0C    | b₃ P0C3             |                        |
| (P0C)   | 80             | P0C <sub>2</sub> | (group    |       |             |        | b <sub>2</sub> P0C2 |                        |
|         | 1              | P0C <sub>1</sub> | I/O)      |       |             |        | b <sub>1</sub> P0C1 |                        |
|         | 2              | P0C₀             |           |       |             |        | bo P0C0             |                        |
| Poer 0D | 75             | P0D <sub>3</sub> | Input     |       | 73H         | P0D    | b <sub>3</sub> P0D3 |                        |
| (P0D)   | 76             | P0D <sub>2</sub> |           |       |             |        | b <sub>2</sub> P0D2 |                        |
|         | 77             | P0D <sub>1</sub> |           |       |             |        | b <sub>1</sub> P0D1 |                        |
|         | 78             | P0D₀             |           |       |             |        | bo PODO             |                        |
| Port 1A | 14             | P1A <sub>3</sub> | I/O       | BANK1 | 70H         | P1A    | b₃ P1A3             |                        |
| (P1A)   | 15             | P1A <sub>2</sub> | (bit I/O) |       |             |        | b <sub>2</sub> P1A2 |                        |
|         | 16             | P1A <sub>1</sub> |           |       |             |        | b <sub>1</sub> P1A1 |                        |
|         | 17             | P1A <sub>0</sub> |           |       |             |        | bo P1A0             |                        |
| Port 1B | 18             | P1B <sub>3</sub> | Output    |       | 71H         | P1B    | b <sub>3</sub> P1B3 |                        |
| (P1B)   | 19             | P1B <sub>2</sub> |           |       |             |        | b <sub>2</sub> P1B2 |                        |
|         | 20             | P1B <sub>1</sub> |           |       |             |        | b <sub>1</sub> P1B1 |                        |
|         | 21             | P1B <sub>0</sub> |           |       |             |        | b <sub>0</sub> P1B0 |                        |
| Port 1C | 22             | P1C <sub>3</sub> | Output    |       | 72H         | P1C    | b₃ P1C3             |                        |
| (P1C)   | 23             | P1C <sub>2</sub> |           |       |             |        | b <sub>2</sub> P1C2 |                        |
|         | 24             | P1C <sub>1</sub> |           |       |             |        | b <sub>1</sub> P1C1 |                        |
|         | 25             | P1C <sub>0</sub> |           |       |             |        | b <sub>0</sub> P1C0 |                        |
| Port 1D | 26             | P1D <sub>3</sub> | Input     |       | 73H         | P1D    | b₃ P1D3             |                        |
| (P1D)   | 27             | P1D <sub>2</sub> |           |       |             |        | b <sub>2</sub> P1D2 |                        |
|         | 28             | P1D <sub>1</sub> |           |       |             |        | b₁ P1D1             |                        |
|         | 29             | P1D₀             |           |       |             |        | b <sub>0</sub> P1D0 |                        |
| Port 2A | No target pins |                  |           | BANK2 | 70H         | P2A    | b₃ P2A3             | Nothing is allocated.  |
| (P2A)   |                |                  |           |       |             |        | b <sub>2</sub> P2A2 | Cannot be used as data |
|         |                |                  | ,         | _     |             |        | b <sub>1</sub> P2A1 | memory.                |
|         | 42             | P2A <sub>0</sub> | Output    |       |             |        | b <sub>0</sub> P2A0 |                        |



Table 15-2. Relation between Each Port (Pin) and Port Register (2/2)

| Port    |     | Pin              |        | Setting of Data       |              |             |                |                          |                        |  |
|---------|-----|------------------|--------|-----------------------|--------------|-------------|----------------|--------------------------|------------------------|--|
|         | No. | o. Symbol        | I/O    |                       | Port registe | er (data me | mory           | )                        | Remark                 |  |
|         |     |                  |        | Bank                  | Address      | Symbol      |                | it symbol<br>erved word) |                        |  |
|         | '   |                  |        | BANK2                 | 71H          | _           | bз             | _                        | Nothing is allocated.  |  |
|         |     |                  |        |                       |              |             | b <sub>2</sub> |                          | Cannot be used as data |  |
|         |     |                  |        |                       |              |             | b <sub>1</sub> |                          | memory.                |  |
|         |     |                  |        |                       |              |             | b <sub>0</sub> |                          |                        |  |
|         |     |                  |        |                       | 72H          | -           | bз             | -                        |                        |  |
|         |     |                  |        |                       |              |             | b <sub>2</sub> |                          |                        |  |
|         |     |                  |        |                       |              |             | b <sub>1</sub> |                          |                        |  |
|         |     |                  |        |                       |              |             | b <sub>0</sub> |                          |                        |  |
|         |     |                  |        |                       | 73H          | _           | Ьз             | _                        |                        |  |
|         |     |                  |        |                       |              |             | b <sub>2</sub> |                          |                        |  |
|         |     |                  |        |                       |              |             | b <sub>1</sub> |                          |                        |  |
|         |     |                  |        | Note                  |              |             | b <sub>0</sub> |                          |                        |  |
|         |     |                  |        | BANK3 <sup>Note</sup> | 70H          | _           | bз             | _                        | Nothing is allocated.  |  |
|         |     |                  |        |                       |              |             | b <sub>2</sub> |                          | Cannot be used as data |  |
|         |     |                  |        |                       |              |             | b <sub>1</sub> |                          | memory.                |  |
|         |     |                  |        |                       | 71H          |             | b <sub>0</sub> |                          |                        |  |
|         |     |                  |        |                       | 7111         | _           | b <sub>2</sub> | _                        |                        |  |
|         |     |                  |        |                       |              |             | b <sub>1</sub> |                          |                        |  |
|         |     |                  |        |                       |              |             | bo             |                          |                        |  |
|         |     |                  |        |                       | 72H          |             | bз             | _                        |                        |  |
|         |     |                  |        |                       |              |             | b <sub>2</sub> |                          |                        |  |
|         |     |                  |        |                       |              |             | b <sub>1</sub> |                          |                        |  |
|         |     |                  |        |                       |              |             | b <sub>0</sub> |                          |                        |  |
|         |     |                  |        |                       | 73H          | _           | b <sub>3</sub> | _                        |                        |  |
|         |     |                  |        |                       |              |             | b <sub>2</sub> |                          |                        |  |
|         |     |                  |        |                       |              |             | b <sub>1</sub> |                          |                        |  |
|         |     |                  |        |                       |              |             | b <sub>0</sub> |                          |                        |  |
| Port 0E | 49  | Р0Ез             | Output | BANK0                 | 6BH          | P0E         | bз             | P0E3                     |                        |  |
| (P0E)   | 50  | P0E <sub>2</sub> |        |                       | (multip      | olexed      | b <sub>2</sub> | P0E2                     |                        |  |
|         | 51  | P0E <sub>1</sub> |        |                       | with LC      | DD11)       | b <sub>1</sub> | P0E1                     |                        |  |
|         | 52  | P0E <sub>0</sub> |        |                       |              |             | b <sub>0</sub> | P0E0                     |                        |  |
| Port 0F | 45  | P0F₃             | Output |                       | 6DH          | P0F         | b3             | P0F3                     |                        |  |
| (P0F)   | 46  | P0F <sub>2</sub> |        |                       | (multip      |             | b <sub>2</sub> | P0F2                     |                        |  |
|         | 47  | P0F <sub>1</sub> |        |                       | with LC      | DD13)       | b <sub>1</sub> | P0F1                     |                        |  |
|         | 48  | P0F <sub>0</sub> |        |                       |              |             | b <sub>0</sub> | P0F0                     |                        |  |

**Note** BANK3 is not provided on the  $\mu$ PD17016.



# 15.3 General-Purpose I/O Ports (P0A, P0B, P0C, and P1A)

## 15.3.1 Configuration of I/O ports

The following paragraphs (1) through (3) indicate the configuration of the I/O ports.

(1) P0A (P0A<sub>1</sub> and P0A<sub>0</sub> pins), P0B (P0B<sub>3</sub>, P0B<sub>2</sub>, P0B<sub>1</sub>, and P0B<sub>0</sub> pins), P1A (P1A<sub>3</sub>, P1A<sub>2</sub>, P1A<sub>1</sub>, and P1A<sub>0</sub> pins)



(2) P0C (P0C<sub>3</sub>, P0C<sub>2</sub>, P0C<sub>1</sub>, and P0C<sub>0</sub> pins)





### (3) POA (POA<sub>3</sub> and POA<sub>2</sub> pins)



## 15.3.2 Using I/O ports

The I/O ports are set in the input or output mode by I/O select registers P0A P0B, P0C, and P1A of the control registers.

The bit I/O ports (P0A, P0B, and P1A) can be set in the input or output mode in 1-bit units, and group I/O port (P0C) can be set in the input or output mode in 4-bit units.

Output data can be set to a port by writing the data to the corresponding port register, and the input data of the port can be read by executing an instruction that reads the port register.

- 15.3.3 explains the I/O select register of each port.
- 15.3.4 and 15.3.5 explain how to use the input and output ports.
- 15.3.6 explains the points to be noted in using the I/O ports.



### 15.3.3 Port 0A bit I/O select register

Port 0B bit I/O select register

Port 1A bit I/O select register

Port 0C group I/O select register

The port 0A bit I/O, port 0B bit I/O, port 1A bit I/O, and port 0C group I/O select registers sets each pin of the P0A, P0B, P1A, and P0C in the input or output mode.

The configuration and functions of these registers are shown below.

### (1) Port 0A bit I/O select register





### (2) Port 0B bit I/O select register





## (3) Port 1A bit I/O select register





# (4) Port 0C group I/O select register



| l to   | Power-ON   | 0 | 0 | 0 | 0 |
|--------|------------|---|---|---|---|
| l rest | Clock stop |   |   |   | 0 |
| Ŏ      | CE         |   |   |   | 0 |

#### 15.3.4 Using I/O ports (P0A, P0B, P0C, and P1A) as input ports

Select the pin that is used as an input port pin by the I/O select register corresponding to each port.

Note that POC can be set in the input or output mode in 4-bit units only.

The pin specified as an input port pin is floated (Hi-Z), and waits for input of an external signal.

The input data can be read by executing an instruction that reads the contents of the port register corresponding to each port, such as "SKT" instruction.

When a high level is input to each pin, "1" is read to the corresponding port register; when a low level is input, "0" is read.

If a write instruction, such as "MOV", is executed to the port register corresponding to the port pin specified as an input port pin, the contents of the output latch are rewritten.

### 15.3.5 Using I/O ports (P0A, P0B, P0C, and P1A) as output ports

Select the pin that is used as an output port pin by the I/O select register corresponding to each port.

Note that POC can be set in the input or output mode in 4-bit units only.

The pin specified as an output port pin outputs the contents of the output latch.

The output data can be set by executing an instruction that writes the contents of the corresponding port register to each pin, such as "MOV" instruction.

To output a high level to each pin, write "1" to the corresponding port register; to output a low level, write "0".

The port pin can also be floated when it is specified as an input port pin.

When an instruction, such as "SKT", that reads the contents of the port register corresponding to a port specified as an output port is executed, the contents of the output latch are read.

Note, however, that the statuses of the P0A<sub>3</sub> and P0A<sub>2</sub> pins are read as is, and the read contents may be different from the contents of the output latch.

Refer to 15.3.6.



#### 15.3.6 Notes on using I/O ports (P0A<sub>3</sub> and P0A<sub>2</sub> pins)

When using the  $P0A_3$  and  $P0A_2$  pins as output pins, the contents of the output latch may be rewritten, as shown in the example below.

### Example To specify P0A3 and P0A2 pins as output port pins

```
INITFLG POABIO3, POABIO2, NOT POABIO1, NOT POABIO0
; Sets POA3 and POA2 pins in output mode

INITFLG POA3, POA2, NOT POA1, NOT POA0
; Outputs high level to POA3 and POA2 pins

;<1>
CLR1 POA3 ; Outputs low level to POA3 pin

Macro expansion

AND . MF. POA3 SHR 4, # .DF. (NOT POA3 AND OFH)
```

If the P0A<sub>2</sub> pin happens to be lowered by an external device when the instruction in <1> above is executed, the contents of the output latch of the P0A<sub>2</sub> pin are rewritten to "0" by the "CLR1" instruction.

In other words, if an operation instruction (such as "ADD" and "OR") to the P0A port register when the P0A<sub>3</sub> or P0A<sub>2</sub> pin is set in the output mode, the contents of the output latch are rewritten to the current level of the pin, regardless of the previous status of the pin.

## 15.3.7 Status of I/O ports (P0A, P0B, P0C, and P1A) on reset

### (1) On power-ON reset

All the I/O ports are set in the input mode.

Because the contents of the output latch are "undefined", the output latch must be initialized by program, as necessary, before setting the corresponding port in the output mode.

#### (2) On CE reset

All the I/O ports are set in the input mode.

The contents of the output latch are retained.

### (3) On execution of clock stop instruction

All the I/O ports are set in the input mode.

The contents of the output latch are retained.

The I/O ports other than POC prevents an increase in the current dissipation due to the noise of the input buffer by using the RESET signal when the clock stop instruction is executed, as explained in 15.3.1.

If P0C is floated on execution of the clock stop instruction, the current dissipation may increase due to external noise. Externally pull this port down or up as necessary.

#### (4) In halt status

The previous status is retained.



## 15.4 General-Purpose Input Ports (P0D and P1D)

# 15.4.1 Configuration of input ports

The following paragraphs (1) and (2) indicate the configuration of the input ports.

# (1) P0D (P0D<sub>3</sub>, P0D<sub>2</sub>, P0D<sub>1</sub>, and P0D<sub>0</sub> pins)



# (2) P1D (P1D<sub>3</sub>, P1D<sub>2</sub>, P1D<sub>1</sub>, and P1D<sub>0</sub> pins)





#### 15.4.2 Using input ports (P0D and P1D)

The input data is read by executing an instruction, such as "SKT", that reads the contents of the port register corresponding to each port pin.

When a high level is input to each pin, "1" is read to the corresponding port register; when a low level is input, "0" is read.

Nothing is changed even if a write instruction, such as "MOV", is executed to the port register.

#### 15.4.3 Notes on using input port (P0D)

The P0D is internally pulled down when it is used as a general-purpose port.

## 15.4.4 Status of input ports (P0D and P1D) on reset

## (1) On power-ON reset

All the input ports are specified as general-purpose input ports.

#### (2) On CE reset

All the input ports are specified as general-purpose input ports.

### (3) On execution of clock stop instruction

All the input ports are specified as general-purpose input ports.

Because the RESET signal is output when the clock stop instruction is executed, the P1D prevents an increase in the current dissipation due to the noise of the input buffer.

The P0D is internally pulled down.

#### (4) In halt status

The previous status is retained.

NEC

# 15.5 General-Purpose Output Ports (P1B, P1C, and P2A)

# 15.5.1 Configuration of output ports (P1B, P1C, and P2A)

The following paragraphs (1) and (2) indicate the configuration of the output ports.

(1) P1B (P1B<sub>0</sub> pin), P1C (P1C<sub>3</sub>, P1C<sub>2</sub>, P1C<sub>1</sub>, and P1C<sub>0</sub> pins), P2A (P2A<sub>0</sub> pin)



## (2) P1B (P1B<sub>3</sub>, P1B<sub>2</sub>, and P1B<sub>1</sub> pins)





#### 15.5.2 Example of using output ports (P1B, P1C, and P2A)

The output ports output the contents of the output latches.

The output data is set by executing an instruction, such as "MOV", that writes the data to the port register corresponding to the output port.

Write "1" to the port register to output a high level to the corresponding port; write "0" to output a low level.

Note, however, that the P1B<sub>3</sub>, P1B<sub>2</sub>, and P1B<sub>1</sub> pins are N-ch open-drain output pins and are floated when a high level is output.

When an instruction, such as "SKT", that reads the contents of the port register is read, the contents of the output latch are read.

### 15.5.3 Status of output ports (P1B, P1C, and P2A) on reset

### (1) On power-ON reset

The contents of the output latch are output.

Because the contents of the output latch are "undefined", an "undefined" value is output for a fixed period (until the output latch is initialized by program).

### (2) On CE reset

The contents of the output latch are output.

The contents of the output latch are retained and the output data are not changed on CE reset.

## (3) On execution of clock stop instruction

The contents of the output latch are output.

The contents of the output latch are retained and the output data are not changed on execution of the clock stop instruction.

Therefore, initialize the output latch in the program as necessary.

### (4) In halt status

The contents of the output latch are output.

The contents of the output latch are retained and the output data are not changed in the halt status.

## 15.6 General-Purpose Output Ports (P0E and P0F)

## 15.6.1 Configuration of output ports (P0E and P0F)

The configuration of the output ports is shown below.

P0E (P0E<sub>3</sub>, P0E<sub>2</sub>, P0E<sub>1</sub>, and P0E<sub>0</sub> pins) P0F (P0F<sub>3</sub>, P0F<sub>2</sub>, P0F<sub>1</sub>, and P0F<sub>0</sub> pins)



## 15.6.2 Example of using output ports (P0E and P0F)

Each pin of the P0E and P0F are used as an LCD segment signal output pin on power-ON reset.

To use it as an output port pin, select the port to be used by a software macro supplied with the device file.

The port to be used can be selected independently.

The pins not set in the output port mode can be used as LCD segment signal output pins.

Table 15-3 shows the software macros that set the ports (P0E and P0F).



Table 15-3. Software Macros Setting Ports (P0E and P0F)

| Function                                                                                                                                                                                                                               | Macro Format         |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as general-purpose output port                                                                                                                      | SET1_P0EON           |
| Uses LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as general-purpose output port                                                                                                                      | SET1_P0FON           |
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as general-purpose output port                                    | SET2_P0EON_P0FON     |
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as LCD segment signal output pins                                                                                                                   | CLR1_P0EON           |
| Uses LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as LCD segment signal output pins                                                                                                                   | CLR1_P0FON           |
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as LCD segment signal output pins                                      | CLR2_P0EON_P0FON     |
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as LCD segment signal output pins and LCD <sub>26</sub> / P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as general-purpose output port | INIT_NOT_P0EON_P0FON |
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as general-purpose output port and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as LCD segment signal output pins  | INIT_P0EON_NOT_P0FON |

# Caution If the above macros are used, the contents of the window register are destroyed.

If the above macros are immediately follow an embedded macro instruction, an "object error" occurs when the source file is assembled and loaded to the in-circuit emulator. If an embedded macro is used before the above macros, insert a comment statement in between them.

#### 15.6.3 Setting data to P0E and P0F

Output data are set to the P0E and P0F by executing an instruction, such as "MOV", that writes data to the port registers corresponding to the ports.

To output a high level to each port pin, write "1" to the corresponding port register; to output a low level, write "0".

The contents of the output latch are read when an instruction, such as "SKT", that reads the contents of the port register is executed.

Figure 15-3 shows the relation between the P0F port register and LCD segment register.

As shown in this figure, LCD segment register LCDD14 can be used as a general-purpose data memory area when the P0F is used.

The same applies to the P0E.

Refer to Figure 21-6. Relation among LCD Display Dots, Ports 0E and 0F, Key Source Output, and Each Data Setting Register in 21. LCD CONTROLLER/DRIVER.

Figure 15-3. Relation between P0F Port Register and LCD Segment Register





### 15.6.4 Status of output ports (P0E and P0F) on reset

### (1) On power-ON reset

The P0E and P0F are set as LCD segment signal output pins and output a low level.

Because the contents of the output latch are undefined, undefined data is output if these ports are set in the output mode as is. Initialize the ports in the program as necessary.

#### (2) On CE reset

The P0E and P0F are set as LCD segment signal output pins and output a low level.

Because the contents of the output latch are retained, the previous values are retained if these ports are set in the output mode as is.

## (3) On execution of clock stop instruction

The P0E and P0F are set as LCD segment signal output pins and output a low level.

Because the contents of the output latch are retained, the previous values are retained if these ports are set in the output mode as is.

### (4) In halt status

The contents of the output latch are output.

Because the contents of the output latch are retained, the output data are not changed in the halt status.



### 16. A/D CONVERTER (ADC)

The A/D converter is used to input an external analog signal as a digital signal.

### 16.1 Configuration of A/D Converter

Figure 16-1 shows the block diagram of the A/D converter.

As shown in the figure, the A/D converter consists of an input select block, compare voltage generation block, and compare block.

Data buffer Control register P0D₃/ADC₅ ○ P0D<sub>2</sub>/ADC<sub>4</sub> O-6 P0D₁/ADC₃ ○ Input select Compare P0D<sub>0</sub>/ADC<sub>2</sub> Oblock block P1D₁/ADC₁ ○ P1D₀/ADC₀ ○ Compare voltage generation block (R-string D/A converter)

Figure 16-1. Block Diagram of A/D Converter

### 16.2 Functional Outline of A/D Converter

The A/D converter compares the voltage input to the P0D<sub>3</sub>/ADC<sub>5</sub> to P1D<sub>0</sub>/ADC<sub>0</sub> pin with an internal compare voltage, and outputs the result of the comparison as "True (1)" or "False (0)".

By judging this comparison result by software, the A/D converter can be used as a successive approximation converter.

The following subsections 16.2.1 through 16.2.3 outline the function of each block of the A/D converter. For details, refer to 16.3 through 16.5.

### 16.2.1 Input select block

This block selects which of the P0D<sub>3</sub>/ADC<sub>5</sub> through P1D<sub>0</sub>/ADC<sub>0</sub> pins is to be used.

The pin is selected by the A/D converter channel select register (RF address 14H).

Only one pin can be selected at a time.

Refer to 16.3.

### 16.2.2 Compare voltage generation block

This block generates a compare voltage against which an input voltage is to be compared.

The compare voltage is generated by an R-string D/A converter.

Refer to 16.4.



### 16.2.3 Compare block

This block compares an input voltage with an internal compare voltage.

The result of the comparison is detected by the A/D converter compare judge register (RF address 06H). Refer to **16.5**.

# 16.3 Input Select Block

## 16.3.1 Configuration of input select block

Figure 16-2 shows the configuration of the input select block.

Figure 16-2. Configuration of Input Select Block





#### 16.3.2 Function of input select block

The input select block selects a pin to be used by using the A/D converter channel select register.

Only one pin can be used as an A/D converter pin at a time.

The pin not selected for the A/D converter can be used as general-purpose input port.

Although port 0D (P0D<sub>3</sub>/ADC<sub>5</sub> through P0D<sub>0</sub>/ADC<sub>2</sub> pins) is internally connected to a pull-down resistor, the pin selected by the A/D converter channel select register (refer to **16.3.3**) is disconnected from the pull-down resistor as soon as it has been selected.

The pins not selected remain connected to the pull-down resistor.

### 16.3.3 Configuration and function of A/D converter channel select register

The A/D converter channel select register selects a pin to be used for the A/D converter.

The configuration and function of this register are shown below.

| Name                  | F           | lag s            | symbo            | ol               | Address                                                | Read/          |                                  |  |  |  |
|-----------------------|-------------|------------------|------------------|------------------|--------------------------------------------------------|----------------|----------------------------------|--|--|--|
|                       | bз          | b <sub>2</sub>   | b <sub>1</sub>   | b <sub>0</sub>   |                                                        | Write          |                                  |  |  |  |
| A/D converter channel | A<br>D      | A<br>D           | A<br>D           | A                | 14H                                                    | R/W            |                                  |  |  |  |
| select register       | C<br>H<br>3 | C<br>C<br>H<br>2 | C<br>C<br>H<br>1 | C<br>C<br>H<br>0 |                                                        |                |                                  |  |  |  |
|                       |             |                  |                  |                  |                                                        |                | -                                |  |  |  |
|                       |             |                  |                  | -                |                                                        | Selects        | pin to be used for A/D converter |  |  |  |
|                       |             | 0                | 0                | 0                | P1Do/ADCo pin                                          |                |                                  |  |  |  |
|                       |             | 0                |                  |                  |                                                        |                |                                  |  |  |  |
|                       |             | 0                | 1                | 0                | P0D <sub>0</sub> /ADC <sub>2</sub> pin                 |                |                                  |  |  |  |
|                       |             | 0                | 1                | 1                | P0D <sub>1</sub> /ADC                                  | ₃ pin          |                                  |  |  |  |
|                       |             | 1                | 0                | 0                | P0D <sub>2</sub> /ADC                                  | 4 pin          |                                  |  |  |  |
|                       |             | 1                | 0                | 1                | P0D3/ADC                                               | 5 pin          |                                  |  |  |  |
|                       |             | 1                | 1                | 0                | A/D conve                                              | rter is not us | sed (general-purpose input port) |  |  |  |
|                       |             | 1                | 1                | 1                | A/D converter is not used (general-purpose input port) |                |                                  |  |  |  |
|                       |             |                  |                  |                  |                                                        |                |                                  |  |  |  |
|                       |             |                  |                  |                  | Fixed to "0"                                           | ,,             |                                  |  |  |  |

| et    | Power-ON   | ( | ) | 1 | 1 | 1 |
|-------|------------|---|---|---|---|---|
| reset | Clock stop |   |   | 1 | 1 | 1 |
| Ō     | CE         | , | , | 1 | 1 | 1 |

### 16.4 Compare Voltage Generation Block

### 16.4.1 Configuration of compare voltage generator block

Figure 16-3 shows the configuration of the compare voltage generator block.

Data buffer (DBF) Address 0CH 0DH 0EH 0FH DBF2 DBF1 DBF0 Symbol DBF3 Data Don't care Don't care S S В В Peripheral address 02H A/D converter To compare block data register VREF Multiplexer ○<sub>63</sub> Vnn  $\frac{1}{2}R$ R R Reading ADCCMP flag by PEEK

Figure 16-3. Configuration of Compare Voltage Generator Block

#### 16.4.2 Function of compare voltage generator block

The compare voltage generator block switches the multiplexer according to the 6-bit data set to the A/D converter data register (ADCR: peripheral address 02H) and generates a compare voltage.

This block is therefore an R-string D/A converter.

The compare voltage can be adjusted in 64 steps by the R string (resistance division).

The voltage supplied to the R string is the same as the supply voltage VDD of the device.

The voltage is supplied to the resistor of the R string only when the A/D converter compare judge register, which is to be explained later, is detected.

The compare voltage is compared with a voltage input to the compare block from a selected pin.

16.4.3 explains the configuration and function of the A/D converter data register.

Table 16-1 lists the compare voltages.



## 16.4.3 Configuration and function of A/D converter data register (ADCR)

The A/D converter data register sets the compare voltage of the A/D converter.

Because this register is 6 bits long, the low-order 6 bits of the data buffer are valid.





Table 16-1. Set Values of A/D Converter Data Register and Compare Voltages

| Set Data of ADCR |                      | Compare                                    | Voltage                             | Set Da           | ita of ADCR       | Compare                                    | e Voltage                           |
|------------------|----------------------|--------------------------------------------|-------------------------------------|------------------|-------------------|--------------------------------------------|-------------------------------------|
| Decimal<br>(DEC) | Hexadecimal<br>(HEX) | Logic voltage<br>Unit: × V <sub>DD</sub> V | At V <sub>DD</sub> = 5 V<br>Unit: V | Decimal<br>(DEC) | Hexadecimal (HEX) | Logic voltage<br>Unit: × V <sub>DD</sub> V | At V <sub>DD</sub> = 5 V<br>Unit: V |
| 0                | 00H                  | 0                                          | 0                                   | 32               | 20H               | 31.5/64                                    | 2.461                               |
| 1                | 01H                  | 0.5/64                                     | 0.039                               | 33               | 21H               | 32.5/64                                    | 2.539                               |
| 2                | 02H                  | 1.5/64                                     | 0.117                               | 34               | 22H               | 33.5/64                                    | 2.617                               |
| 3                | 03H                  | 2.5/64                                     | 0.195                               | 35               | 23H               | 34.5/64                                    | 2.695                               |
| 4                | 04H                  | 3.5/64                                     | 0.273                               | 36               | 24H               | 35.5/64                                    | 2.773                               |
| 5                | 05H                  | 4.5/64                                     | 0.352                               | 37               | 25H               | 36.5/64                                    | 2.852                               |
| 6                | 06H                  | 5.5/64                                     | 0.430                               | 38               | 26H               | 37.5/64                                    | 2.930                               |
| 7                | 07H                  | 6.5/64                                     | 0.508                               | 39               | 27H               | 38.5/64                                    | 3.008                               |
| 8                | 08H                  | 7.5/64                                     | 0.586                               | 40               | 28H               | 39.5/64                                    | 3.086                               |
| 9                | 09H                  | 8.5/64                                     | 0.664                               | 41               | 29H               | 40.5/64                                    | 3.164                               |
| 10               | 0AH                  | 9.5/64                                     | 0.742                               | 42               | 2AH               | 41.5/64                                    | 3.242                               |
| 11               | 0BH                  | 10.5/64                                    | 0.820                               | 43               | 2BH               | 42.5/64                                    | 3.320                               |
| 12               | 0CH                  | 11.5/64                                    | 0.898                               | 44               | 2CH               | 43.5/64                                    | 3.398                               |
| 13               | 0DH                  | 12.5/64                                    | 0.977                               | 45               | 2DH               | 44.5/64                                    | 3.477                               |
| 14               | 0EH                  | 13.5/64                                    | 1.055                               | 46               | 2EH               | 45.5/64                                    | 3.555                               |
| 15               | 0FH                  | 14.5/64                                    | 1.133                               | 47               | 2FH               | 46.5/64                                    | 3.633                               |
| 16               | 10H                  | 15.5/64                                    | 1.211                               | 48               | 30H               | 47.5/64                                    | 3.711                               |
| 17               | 11H                  | 16.5/64                                    | 1.289                               | 49               | 31H               | 48.5/64                                    | 3.789                               |
| 18               | 12H                  | 17.5/64                                    | 1.367                               | 50               | 32H               | 49.5/64                                    | 3.867                               |
| 19               | 13H                  | 18.5/64                                    | 1.445                               | 51               | 33H               | 50.5/64                                    | 3.945                               |
| 20               | 14H                  | 19.5/64                                    | 1.523                               | 52               | 34H               | 51.5/64                                    | 4.023                               |
| 21               | 15H                  | 20.5/64                                    | 1.602                               | 53               | 35H               | 52.5/64                                    | 4.102                               |
| 22               | 16H                  | 21.5/64                                    | 1.680                               | 54               | 36H               | 53.5/64                                    | 4.180                               |
| 23               | 17H                  | 22.5/64                                    | 1.758                               | 55               | 37H               | 54.5/64                                    | 4.258                               |
| 24               | 18H                  | 23.5/64                                    | 1.836                               | 56               | 38H               | 55.5/64                                    | 4.336                               |
| 25               | 19H                  | 24.5/64                                    | 1.914                               | 57               | 39H               | 56.5/64                                    | 4.414                               |
| 26               | 1AH                  | 25.5/64                                    | 1.992                               | 58               | ЗАН               | 57.5/64                                    | 4.492                               |
| 27               | 1BH                  | 26.5/64                                    | 2.070                               | 59               | 3ВН               | 58.5/64                                    | 4.570                               |
| 28               | 1CH                  | 27.5/64                                    | 2.148                               | 60               | 3CH               | 59.5/64                                    | 4.648                               |
| 29               | 1DH                  | 28.5/64                                    | 2.227                               | 61               | 3DH               | 60.5/64                                    | 4.727                               |
| 30               | 1EH                  | 29.5/64                                    | 2.305                               | 62               | 3EH               | 61.5/64                                    | 4.805                               |
| 31               | 1FH                  | 30.5/64                                    | 2.383                               | 63               | 3FH               | 62.5/64                                    | 4.883                               |



### 16.5 Compare Block

### 16.5.1 Configuration of compare block

Figure 16-4 shows the configuration of the compare block.

Figure 16-4. Configuration of Compare Block



## 16.5.2 Function of compare block

The compare block compares the voltage Vadcin input from a pin with the internal compare voltage VREF by using a comparator and outputs the result of the comparison to the compare judge FF.

The compare judge FF can be detected by reading the ADCCMP flag of the A/D converter compare judge register.

The ADCCMP flag is set when Vadcin > VREF and reset when Vadcin < VREF.

The comparator performs comparison when the ADCCMP flag has been read.

In other words, when the ADCCMP flag has been read by using the "PEEK" instruction, comparison is performed by manipulating switches 1 and 2.

Therefore, the time required for the A/D converter to perform comparison once is equal to one instruction execution time (4.44  $\mu$ s).

16.5.3 explains the configuration and function of the A/D converter compare judge register.

### 16.5.3 Configuration and function of A/D converter compare judge register

The A/D converter compare judge register detects the result of comparison between input voltage Vadcin and compare voltage VREF.

The configuration and function of this register are illustrated below.



## 16.6 Performances of A/D Converter

The performances of the A/D converter are as follows.

| Parameter                                | Performance                  |
|------------------------------------------|------------------------------|
| Resolution                               | 1LSB                         |
| Input voltage range                      | 0-V <sub>DD</sub>            |
| Quantization error                       | $\pm \frac{1}{2}$ LSB        |
| Over range                               | 62.5<br>64 × V <sub>DD</sub> |
| Error of offset, gain, and non-linearity | $\pm \frac{3}{2}$ LSBNote    |

Note Including quantization error.



### 16.7 Using A/D Converter

### 16.7.1 Comparing one compare voltage

Here is a program example.

**Example** To compare input voltage VADCIN of ADC<sub>0</sub> pin with compare voltage VREF (31.5/64 VDD) and branch to AAA if VADCIN > VREF or to BBB if VADCIN < VREF

```
INIT:
              FLG 0.0EH.3
                                  ; Dummy
    ADCR7
    ADCR6
              FLG
                   0.0EH.2
                                  ; Dummy
              FLG 0.0EH.1
                                  ; Defines each bit of data buffer as ADCR data setting
    ADCR5
    ADCR4
              FLG 0.0EH.0
                                  ; flag
    ADCR3
              FLG
                   0.0FH.3
    ADCR2
              FLG 0.0FH.2
              FLG 0.0FH.1
    ADCR1
              FLG 0.0FH.0
    ADCR0
              ADCCH2, ADCCH1, ADCCH0
    CLR3
                                  ; Sets P1D<sub>0</sub>/ADC<sub>0</sub> pin for the A/D converter
START:
    INITFLG NOT ADCR3, NOT ADCR2, NOT ADCR1, NOT ADCR0
                                             ADCR5, NOT ADCR4
    INITFLG NOT ADCR7, NOT ADCR6,
    PUT
              ADCR, DBF
                                  ; Sets compare voltage VREF to 31.5/64 VDD
                                  ; Detects ADCCMP flag, and
              ADCCMP
    SKT1
                                  ; branches to AAA if False (0)
    BR
              AAA
    BR
              BBB
                                  ; branches to BBB if True (1)
```

#### 16.7.2 Successive approximation by binary search method

The A/D converter can compare only one voltage at one time.

To convert an input voltage into a digital signal, therefore, successive approximation must be executed by program.

If the processing time of the successive approximation program differs depending on the input voltage, the relation with the other processing programs is undesirable.

Therefore, use of the binary search method as explained in (1) through (3) below is recommended.

## (1) Concept of binary search

The concept of binary search is explained below.

First, the compare voltage is set to 1/2 Vdd. If the result of comparison is True (a high level is input), a voltage of 1/4 Vdd is added to the result; if the result of comparison is False (a low level is input), a voltage of 1/4 Vdd is subtracted from the result and compared.

Subsequently, the compare voltage is sequentially compared with  $1/8~V_{DD}$  and  $1/16~V_{DD}$  to  $1/64~V_{DD}$ . If the result of comparison is False after comparison has been executed six times,  $1/64~V_{DD}$  is subtracted from the result and comparison is completed.





#### (2) Flowchart of binary search method



#### (3) Program example of binary search method

#### (a) Method with short conversion time

```
INIT:
      ADCR7
               FLG 0.0EH.3
                                  ; Dummy
      ADCR6
               FLG 0.0EH.2
                                  ; Dummy
      ADCR5
               FLG 0.0EH.1
                                  ; Defines each bit of data buffer as ADCR data setting flag
               FLG 0.0EH.0
      ADCR4
      ADCR3
               FLG 0.0FH.3
      ADCR2
               FLG 0.0FH.2
      ADCR1
               FLG 0.0FH.1
               FLG 0.0FH.0
      ADCR0
      CLR3
               ADCCH2, ADCCH1, ADCCH0
                                  ; Sets P1D<sub>0</sub>/ADC<sub>0</sub> pin for the A/D converter
START:
      INITFLG NOT ADCR3, NOT ADCR2, NOT ADCR1, NOT ADCR0
      INITFLG NOT ADCR7, NOT ADCR6,
                                                ADCR5, NOT ADCR4
               ADCR, DBF
                                  ; Sets compare voltage to 31.5/64 VDD
      PUT
                                  ; Detects ADCCMP and subtracts
      SKT1
               ADCCMP
                                  : 32/64 Vpp if "0" and adds
      CLR1
               ADCR5
                                  ; 16/64 VDD
               ADCR4
      SET1
      PUT
               ADCR, DBF
      SKT1
               ADCCMP
                                  ; Detects ADCCMP and subtracts
                                  ; 16/64 VDD if "0" and adds
      CLR1
               ADCR4
               ADCR3
                                  ; 8/64 VDD
      SET1
      PUT
               ADCR, DBF
                                  ; Detects ADCCMP and subtracts
      SKT1
               ADCCMP
      CLR1
               ADCR3
                                  ; 8/64 V<sub>DD</sub> if "0" and adds
                                                                       A/D conversion
      SET1
               ADCR2
                                  ; 4/64 VDD
      PUT
               ADCR, DBF
               ADCCMP
                                  ; Detects ADCCMP and subtracts
      SKT1
                                  ; 4/64 V<sub>DD</sub> if "0" and adds
      CLR1
               ADCR2
                                  : 2/64 VDD
      SET1
               ADCR1
      PUT
               ADCR, DBF
      SKT1
               ADCCMP
                                  ; Detects ADCCMP and subtracts
      CLR1
               ADCR1
                                  ; 2/64 VDD if "0" and adds
                                  ; 1/64 VDD
      SET1
               ADCR0
               ADCR, DBF
      PUT
      SKT1
               ADCCMP
                                  ; Detects ADCCMP and subtracts
                                  ; 1/64 VDD if "0"
      CLR1
               ADCR0
END:
```

Number of program steps : 31 steps Number of execution steps: 31 steps A/D conversion time : 137.8  $\mu$ s

A/D

conversion



### (b) Method with fewer program steps

ADWORK1 MEM 0.00H ; Work area for changing compare voltage ADWORK0 MEM 0.01H INITFLG NOT ADCCH2, NOT ADCCH1, NOT ADCCH0 ; Sets P1D<sub>0</sub>/ADC<sub>0</sub> pin for the A/D converter START: DBF1, #0010B ; Sets compare voltage to initial value of 31.5/64 VDD MOV DBF0, #0000B MOV ADWORK1, #0001B MOV ADWORKO, #0000B MOV AD\_CHECK: PUT ADCR, DBF ; Sets compare voltage VREF ; Detects ADCCMP flag SKT1 ADCCMP BR ADIN\_L DBF0, ADWORK0 ; Increases compare voltage if "1" ADD ADDC DBF1, ADWORK1 BR NEXT\_AD ADIN\_L: SUB DBF0, ADWORKO ; Decreases compare voltage if "0" DBF1, ADWORK1 SUBC ; Described to keep A/D conversion time constant NOP NEXT\_AD: RORC ADWORK1 RORC ADWORK0 SKT1 ; 6 bits completed? CY AD\_CHECK PUT ADCR, DBF SKT1 ADCCMP

> Number of program steps : 22 steps Number of execution steps: 58 to 63 steps A/D conversion time : 257.8 to 280  $\mu$ s

DBF0, #1110B

AND

Where the A/D conversion time is held constant

Number of program steps : 23 steps Number of execution steps: 63 steps A/D conversion time : 280  $\mu$ s



#### 16.8 Notes on Using A/D Converter

When the P0D<sub>3</sub>/ADC<sub>5</sub> to P0D<sub>0</sub>/ADC<sub>2</sub> pin is used for the A/D converter and if it is specified that the halt status can be released by key input, the halt status may not be set.

This happens because, as explained in 12.4 Halt Function, the pin selected for the A/D converter is disconnected from the latch of the input port.

Figure 16-5 shows the relation between the P0D₃/ADC₅ through P0D₀/ADC₂ pins and input latch.

As shown in this figure, if a high level is input to the input pin when the A/D converter is set by the A/D converter select signal, the status "1" of input latch is retained.

Even if an attempt is made to set the state where the halt status is released by key input at this time, therefore, since a high level is being input to this pin, the halt status is immediately released.

Figure 16-5. Relation between P0D<sub>3</sub>/ADC<sub>5</sub> through P0D<sub>0</sub>/ADC<sub>2</sub> Pins and Input Latch



#### 16.9 Status on Reset

### 16.9.1 On power-ON reset

All the P0D $_3$ /ADC $_5$  through P0D $_0$ /ADC $_2$  pins, P1D $_1$ /ADC $_1$ , and P1D $_0$ /ADC $_0$  pins are set in the general-purpose input port mode.

## 16.9.2 On execution of clock stop instruction

All the P0D<sub>3</sub>/ADC<sub>5</sub> through P0D<sub>0</sub>/ADC<sub>2</sub> pins, P1D<sub>1</sub>/ADC<sub>1</sub>, and P1D<sub>0</sub>/ADC<sub>0</sub> pins are set in the general-purpose input port mode.

#### 16.9.3 On CE reset

All the  $P0D_3/ADC_5$  through  $P0D_0/ADC_2$  pins,  $P1D_1/ADC_1$ , and  $P1D_0/ADC_0$  pins are set in the general-purpose input port mode.



### 17. D/A CONVERTER (DAC)

The D/A converter (DAC) outputs its signal by means of PWM (Pulse Width Modulation) that varies the duty factor.

By connecting an external lowpass filter to the D/A converter, digital signals can be converted into analog signals.

### 17.1 Configuration of D/A Converter

Figure 17-1 shows the block diagram of the D/A converter.

As shown in the figure, the D/A converter consists of an output select block and a duty setting block for each pin, and a clock generation block.



Figure 17-1. Block Diagram of D/A Converter

#### 17.2 Functional Outline of D/A Converter

The D/A converter outputs a variable-duty signal to each output pin.

The output frequency is 878.9 Hz, and the duty factor can be changed in 256 steps.

The following subsections 17.2.1 through 17.2.3 outlines the function of each block of the D/A converter.

### 17.2.1 Output select blocks

The output select blocks specify whether each pin is used as a general-purpose output port pin or a D/A converter pin.

The mode of each pin is selected by the PWM pin setting software macro supplied with the device file (refer to 17.3).

### 17.2.2 Duty setting blocks

The duty setting blocks output a signal whose duty factor can be changed in 256 steps.

The duty factor of each output pin is independently set by the PWM data register (PWMR0 or PWMR1: peripheral address 05H or 06H) via the data buffer.

### 17.2.3 Clock generation block

The clock generation block generates a basic clock that is used to set the duty factor of the output signal. The generated clock frequency fpwm is 225 kHz (refer to **17.4**).



### 17.3 Output Select Blocks

# 17.3.1 Configuration of output select blocks

Figure 17-2 shows the configuration of the output select blocks.

P1B<sub>2</sub>/PWM<sub>1</sub> O Duty setting block
P1B<sub>1</sub>/PWM<sub>0</sub> O Duty setting block
Output latch
Output latch

Figure 17-2. Configuration of Output Select Blocks

#### 17.3.2 Function of output select blocks

The output select blocks select whether the P1B<sub>2</sub>/PWM<sub>1</sub> and P1B<sub>1</sub>/PWM<sub>0</sub> are used as general-purpose output port pins or D/A converter pins.

This selection can be made by the PWM pin setting software macro supplied with the device file. Each pin can be set in the port mode or D/A converter mode independently.

The  $P1B_2/PWM_1$  and  $P1B_1/PWM_0$  pins are N-ch open-drain output pins and must be connected with an external pull-up resistor.

Table 17-1 lists the PWM pin setting software macros.

**Function** Macro Format Uses P1B<sub>1</sub>/PWM<sub>0</sub> pin as PWM pin SET1\_PWM0ON Uses P1B<sub>2</sub>/PWM<sub>1</sub> pin as PWM pin SET1\_PWM1ON Uses P1B<sub>1</sub>/PWM<sub>0</sub> and P1B<sub>2</sub>/PWM<sub>1</sub> pins as PWM pins SET2\_PWM1ON\_PWM0ON Uses P1B<sub>1</sub>/PWM<sub>0</sub> pin as general-purpose output port pin CLR1\_PWM0ON Uses P1B<sub>2</sub>/PWM<sub>1</sub> pin as general-purpose output port pin CLR1\_PWM1ON Uses P1B<sub>1</sub>/PWM<sub>0</sub> and P1B<sub>2</sub>/PWM<sub>1</sub> pins general-purpose output port pins CLR2\_PWM1ON\_PWM0ON Uses P1B<sub>1</sub>/PWM<sub>0</sub> pin as PWM pin and P1B<sub>2</sub>/PWM<sub>1</sub> pin as general-purpose output port pin INIT\_NOT\_PWM1ON\_PWM0ON Uses P1B<sub>1</sub>/PWM<sub>0</sub> pin as general-purpose output port pin and P1B<sub>2</sub>/PWM<sub>1</sub> pin as PWM pin INIT\_PWM1ON\_NOT\_PWM0ON

Table 17-1. PWM Pin Setting Software Macros

#### Caution If the above macros are used, the contents of the register window are destroyed.

If the above macro instructions immediately follow an embedded macro instruction, an "object error" occurs when the source file is assembled and loaded to the in-circuit emulator. If an embedded macro exists immediately before the above macro instructions, insert a comment statement in between.



# 17.4 Duty Setting Blocks and Clock Generation Block

## 17.4.1 Configuration of duty setting blocks and clock generation block

Figure 17-3 shows he configuration of the duty setting blocks and clock generation block.

Figure 17-3. Configuration of Duty Setting Blocks and Clock Generation Block





#### 17.4.2 Function and configuration of clock generation blocks

The clock generation blocks outputs basic clocks (fPWM1 and fPWM0) that set the duty factor of each output signal (of PWM1 and PWM0 pins).

The output frequency is 225 kHz (4.44  $\mu$ s) for both fpwm1 and fpwm0.

However, fpwm1 and fpwm0 have the following phase difference.



# 17.4.3 Function and operation of duty setting blocks

The duty setting blocks compare the value set to each PWM data register (PWM1 and PWM0) with the value of each basic clock (fpwm1 and fpwm0) counted by an 8-bit counter, and output a high level if the value of the PWM data register is greater, and a low level if the value of PWM data register is less.

Where the value set to the PWM data register is "x", the duty factor is as follows.

Duty factor: 
$$D = \frac{x + 0.25}{256} \times 100 \%$$

0.25 is an offset. A high level is output even when x = 0.

Because the basic clock is 225 kHz, the frequency and cycle of the output signal are as follows.

Frequency: 
$$f = \frac{225 \text{ kHz}}{256} = 878.9 \text{ Hz}$$

Cycle : 
$$t = \frac{256}{225 \text{ kHz}} = 1137.8 \ \mu\text{s}$$

An independent value can be set to each PWM data register via the data buffer.

In other words, each pin can output a signal with an independent duty factor.

The following subsections 17.4.4 and 17.4.5 explain the configuration and function of each PWM data register, and the relation between the output waveform and duty factor of each pin.



## 17.4.4 Configuration and function of each PWM data register

The function of each PWM data register is illustrated below.

The PWM data register sets the duty factor of a D/A converter (PWM output) output signal.





#### 17.4.5 Relation of output waveform and each pin of D/A converter

(1) shows the relation between the output waveform and duty factor. (2) shows the relation of the output waveform of each pin.

## (1) Duty factor and output waveform



#### (2) Output waveform of each pin



#### 17.5 Status on Reset

## 17.5.1 On power-ON reset

The P1B<sub>2</sub>/PWM<sub>1</sub> and P1B<sub>1</sub>/PWM<sub>0</sub> pins are set in the general-purpose output port mode.

The output value is "undefined".

The value of each PWM data register is "undefined".

#### 17.5.2 On execution of clock stop instruction

The P1B<sub>2</sub>/PWM<sub>1</sub> and P1B<sub>1</sub>/PWM<sub>0</sub> pins are set in the general-purpose output port mode.

The output value is the "previous contents of the output latch".

Each PWM data register retains the previous value.

# 17.5.3 On CE reset

The P1B<sub>2</sub>/PWM<sub>1</sub> and P1B<sub>1</sub>/PWM<sub>0</sub> pins retain the previous output status.

Therefore, the pin used for the D/A converter retains the current PWM output.

## 17.5.4 In halt status

The P1B<sub>2</sub>/PWM<sub>1</sub> and P1B<sub>1</sub>/PWM<sub>0</sub> pins retain the previous output status.

Therefore, the pin used for the D/A converter retains the current PWM output.



#### 18. BEEP OUTPUT

The BEEP output function outputs a clock of 200 Hz, 1 kHz, or 3 kHz from the P1Bo/BEEP pin.

## 18.1 Method of BEEP Output

The BEEP output function is controlled by a software macro defined in the device file. To start or stop the BEEP output, describe this software macro in the source program.

## (1) Software macro starting BEEP output

This macro sets the frequency of the BEEP output and the P1Bo/BEEP pin in the BEEP output mode, to start the BEEP output.

(a) To output 200 Hz BEEPON200

(b) To output 1 kHz
BEEPON1K

(c) To output 3 kHz
BEEPON3K

## (2) Software macro stopping BEEP output

This macro stops the BEEP output. Consequently, the P1B<sub>0</sub>/BEEP pin can be used as a general-purpose output port pin, and the contents of the output latch at that time can be output.

# (a) To stop BEEP output

**BEEPOFF** 

Caution If the above macros are used, the contents of the register window are destroyed.

If the above macro instructions immediately follow an embedded macro instruction, an "object error" occurs when the source file is assembled and loaded to the in-circuit emulator. If an embedded macro exists immediately before the above macro instructions, insert a comment statement in between.



## 18.2 Output Waveform of BEEP

The duty factor of the output waveform of BEEP is 50 %.

The output waveform is shown below.

## (1) 200-Hz output



## (2) 1-kHz output



## (3) 3-kHz output



## 18.3 Status on Reset

## (1) On power-ON reset

The P1B<sub>0</sub>/BEEP pin is set in the general-purpose output port mode. The value of the output latch is undefined, and therefore undefined data is output.

# (2) On execution of clock stop instruction

The P1B<sub>0</sub>/BEEP pin is set in the general-purpose output port mode. The value of the output latch before the clock stop instruction is executed is retained, and the value of the output latch at that time is output.

## (3) On CE reset

The P1B $_0$ /BEEP pin operates as is with the previous status retained.

# (4) In halt status

The P1B<sub>0</sub>/BEEP pin operates as is with the previous status retained.



## 18.4 Notes on Using BEEP Function

The BEEP function block shares part of the hardware with the frequency counter that is explained later.

Therefore, the BEEP function and frequency counter cannot be used at the same time.

If the data of the IF counter mode select register and IF counter data register (IFC: peripheral address 43H) are manipulated while the BEEP function is being used, the operation explained in 18.4.1 is performed.

If the BEEP output software macro is executed while the frequency counter is being used, the operation explained in 18.4.2 is performed.

#### 18.4.1 When BEEP function is used

## (1) When IFCMD1 and IFCMD0 flags of IF counter mode select register are manipulated

If a value other than "0" is written to the IFCMD1 and IFCMD0 flags, the P1B<sub>0</sub>/BEEP pin retains the current output level, and stops the BEEP output.

When both the IFCMD1 and IFCMD0 flags are reset to "0", the BEEP output is started.

### (2) When IF counter data register is manipulated

The BEEP output is not affected even if the IF counter data register is read (by GET) or written (by PUT). An "undefined value" is read from the register. Nothing is changed even if data is written to the register. However, do not write anything to the IF counter data register because this register is a read-only register.

### 18.4.2 When frequency counter is being used

If the BEEP output software macro is executed while the frequency counter is being used, the frequency counter is forcibly stopped, and the BEEP output is started. At this time, the contents of the window register (WR) and data buffer (DBF) are destroyed. To operate the frequency counter again, stop the BEEP output once by using the BEEPOFF software macro, and start counting from the beginning.

# 19. SERIAL INTERFACE

The serial interface is used to transfer 8-bit serial data with an external device.

POB2/SCK POB1/SO Control Clock control Clock generation

Serial interface

Figure 19-1. Block Diagram of Serial Interface



## 19.1 Configuration of Serial Interface

Figure 19-2 shows the configuration of the serial interface.

As shown in the figure, the shift clock control block of the serial interface consists of a clock I/O pin block, clock generation block, wait control block, and clock count block.

The serial data control block consists of a serial data I/O pin block and a presettable shift register.

These blocks are controlled by the corresponding flags of the control registers.

Data is written to or read from the presettable shift register via the data buffer.

The following section 19.2 outlines each block.

Figure 19-2. Configuration of Serial Interface



#### 19.2 Functional Outline of Serial Interface

The serial interface uses the P0B<sub>2</sub>/SCK, P0B<sub>1</sub>/SO, and P0B<sub>0</sub>/SI pins.

The serial interface can select the internal clock or an external clock, and can execute reception and transfer operations.

The following subsections 19.2.1 through 19.2.6 outline the functions of the respective blocks of the serial interface.

For details of each block, refer to 19.3 through 19.7.

## 19.2.1 Shift clock I/O pin block

This block selects a shift clock I/O pin.

The shift clock I/O pin is selected by the serial I/O mode select register.

Refer to 19.3.

#### 19.2.2 Serial data I/O pin block

This block selects a serial data I/O pin.

The serial data I/O pin is selected by the serial I/O mode select register.

Refer to 19.3.

## 19.2.3 Clock generation block

This block selects the clock frequency of the shift clock and controls the shift clock output timing.

The shift clock frequency is selected by the serial I/O mode select register.

Refer to 19.4.

#### 19.2.4 Clock counter

The clock counter counts the number of rising edges of the clock output by the shift clock output pin and outputs a signal at the eighth clock (SF8 signal).

The SF8 signal is used to make serial communication wait (pause).

Refer to 19.5.

## 19.2.5 Presettable shift register (SIO1SFR)

This shift register sets serial out data and stores serial in data.

It performs a shift operation by using the clock of the shift clock I/O pin and inputs/outputs data.

The output data is set and the input data is read via the data buffer.

Refer to 19.6.

## 19.2.6 Wait control block

This block controls places or releases serial communication in or from the wait status.

Serial communication is placed in or released from the wait status by the serial I/O mode select register.

Refer to 19.7.



#### 19.3 Shift Clock and Serial Data I/O Pin Control Blocks

The shift clock and serial data I/O pin control blocks sets the pins of the serial interface and controls the transfer/reception operation.

These control operations are specified by the serial I/O mode select register.

- 19.3.1 shows the configuration and function of the serial I/O mode select register.
- 19.3.2 indicates the status of each pin set by the serial I/O mode select register.

#### 19.3.1 Configuration and function of serial I/O mode select register

The configuration and function of the serial I/O mode select register are illustrated below.

The SIO1CK1 and SIO1CK0 flags are used to select the internal clock or an external clock and to set the frequency of the internal clock.

For the details on the clock, refer to 19.4.

The SIO1TS flag places or releases the serial interface in or from the wait status.

For the wait operation, refer to 19.7.





## 19.3.2 Pin status setting by serial I/O mode select register

Table 19-1 shows the status of each pin set by the serial I/O mode select register.

As shown in this table, the I/O select flag of each pin must be also manipulated to set each pin.

For the details on the I/O select flag, refer to 15. GENERAL-PURPOSE PORT.

Table 19-1. Pin Status Setting by Serial I/O Mode Select Register

| SIO1MODE             |                       |                                           |               | Pin                              |                    |                       |       |                |   |                                                                                                                                                                                                                                                      |
|----------------------|-----------------------|-------------------------------------------|---------------|----------------------------------|--------------------|-----------------------|-------|----------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Communication mode   | S   O   1   H   I   Z | Setting of serial output                  | S I O 1 C K 1 | bo<br>S<br>I<br>O<br>1<br>C<br>K | Clock<br>direction | Pin symbol            |       | selection of e |   | Set pin status                                                                                                                                                                                                                                       |
| 3-wire<br>serial I/O |                       |                                           | 0             | 1 0                              | External clock     | P0B <sub>2</sub> /SCK | 0 1 0 |                |   | Wait: general-purpose input port Wait released: external clock input Wait: general-purpose output port Wait released: general-purpose output port Wait: general-purpose input port Wait released: general-purpose input port Wait: High level output |
|                      | 0                     | General-<br>purpose port<br>Serial output | 1             | 1                                |                    | P0B <sub>1</sub> /SO  |       | 0 1 0          | 0 | Wait released : General-purpose input port General-purpose input port General-purpose output port General-purpose input port Serial output Serial input General-purpose output port                                                                  |



#### 19.4 Clock Generation Block

The clock generation block generates the clock when the internal clock is used (i.e., when the master operation is performed) and controls the clock output timing.

The frequency fsc of the internal clock is set by using the SIO1CK1 and SIO1CK0 flags of the serial I/O mode select register.

The shift clock is successively output until the value of the clock counter, which is explained in 19.5, reaches "8".

The following subsection 19.4.1 explains the clock output waveform and clock generation timing.

## 19.4.1 Internal shift clock generation timing

## (1) On releasing wait status from initial status

The initial status is the status in which the internal clock is selected, the P0B<sub>2</sub>/SCK pin is set in the output mode, and a high level is output to this pin.

A high level is output to the P0B<sub>2</sub>/SCK pin in the wait status.





## (2) When wait operation is performed

For the details on the wait operation, refer to 19.7.

# (a) Wait status with value of clock counter reaching "8" (normal operation)



## (b) If forced wait is executed in wait status



## (c) If forced wait is executed when wait status is released

At this time, the clock counter is reset.



## (d) If wait status is released in wait release status

The clock output waveform is not changed at this time.

The clock counter is not reset.

## (e) If clock frequency is changed and wait status is released at the same time

The clock frequency can be changed and the wait status can be released by the serial I/O mode select register of the control registers.

Therefore, the clock frequency can be changed and the wait status can be released with a single instruction.

In this case, the operation is the same as releasing the wait status from the initial status as explained in (1).



#### 19.5 Clock Counter

The clock counter is a wrap-around counter that counts the number of the shift clocks output from or input to the shift clock (P0B<sub>2</sub>/<del>SCK</del>) pin.

The clock counter directly reads the status of the shift clock pin. At this time, whether the clock is the internal clock or an external clock is not identified.

The clock counter does not operate in the wait status of serial communication.

When the value of the clock counter is "8", serial communication is placed in the wait status at the rising edge of the shift clock.

The contents of the clock counter cannot be directly read by programs.

The following subsections 19.5.1 and 19.5.2 explain the operation of the clock counter and the conditions under which the clock counter is reset.

## 19.5.1 Operation of clock counter

Figure 19-3 shows the operation of the clock counter.

The initial value of the clock counter is "0". The value of the clock counter is incremented by one each time the falling of the shift clock pin is detected. When the value of the clock counter has been incremented to "8", the clock counter is reset to "0" at the next rising edge of the shift clock pin.

Serial communication is placed in the wait status when the clock counter has been reset to "0".



Figure 19-3. Operation of Clock Counter

### 19.5.2 Clock counter reset condition

The clock counter is reset to 0 when any of the following conditions (1) through (5) is satisfied.

- (1) On power-ON reset
- (2) On execution of the clock stop instruction
- (3) When "0" is written to the SIO1TS flag (forced wait)
- (4) When the shift clock rises while the value of the clock counter is "8" with the wait status released
- (5) On CE reset

## 19.6 Presettable Shift Register (SIO1SFR)

The presettable shift register is an 8-bit shift register that writes serial out data and reads serial in data.

Data is written to or read from the presettable shift register via the data buffer by using the "PUT" or "GET" instruction.

19.6.1 shows the configuration of the presettable shift register and its relation with the data buffer.

The presettable shift register performs its shift operation in synchronization with the clock applied to the shift clock ( $P0B_2/\overline{SCK}$ ) pin.

At this time, the content of the most significant bit (MSB) of the presettable shift register is output to the serial data output pin in synchronization with the fall of the shift clock, and the least significant bit (LSB) of the presettable shift register is read in synchronization with the rise of the clock.

19.6.2 explains the operation of the presettable shift register. 19.6.3 explains the points to be noted in writing or reading data to or from the presettable shift register.

The presettable shift register does not shift data in the wait status.

For the details on the operation in each serial communication mode, refer to 19.8.

### 19.6.1 Configuration of presettable shift register and its relation with data buffer

The configuration of the presettable shift register and its relation with the data buffer are shown below.





## 19.6.2 Operation of presettable shift register

Figure 19-4 illustrates the data shift operation of the presettable shift register.

Table 19-2 shows the data shift operation during transfer and reception.

Shift 2 8 clock pin Wait release 2 Clock 8 0 counter Serial data d7 d6 d5 d2 d1 d0 input pin Serial data D7 D6 D5 D2 D1 D0 output pin b<sub>7</sub> D7 D6 D5 D1 D0 d7 Presettable shift register D5 D4 D0 d7 D6 d6  $b_6$ b<sub>5</sub> D5 D4 D3 d7 d6 d5 b<sub>4</sub> D4 D3 D2 d6 d5 d4 D3 bз D2 D1 d5 d4 d3 D2 b<sub>2</sub> D1 D0 d4 d3 d2 b<sub>1</sub> D1 D0 d7 d3 d2 d1 D0 d7 d6 d2 d1 d0  $b_0$ 

Figure 19-4. Data Shift Operation of Presettable Shift Register

Table 19-2. Data Shift Operation during Transfer and Reception

| Serial I/O mode                                                                                                                                                                                                     |                                                                                                                                                                                                                                     |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Serial input operation                                                                                                                                                                                              | Serial output operation                                                                                                                                                                                                             |  |  |  |  |
| Shifts and inputs status of P0B <sub>0</sub> /SI pin at rising edge of shift clock starting from LSB.  If P0BBIO0 flag is "0", contents of output latch are input.  This operation is not performed in wait status. | Data is shifted and output, starting from MSB, to P0B <sub>1</sub> /SO pin at falling edge of shift clock.  If P0BBIO1 flag is "1", or if SIO1HIZ flag is "0", data is not output.  This operation is not performed in wait status. |  |  |  |  |



## 19.6.3 Notes on setting and reading data

Data is written to the presettable shift register by the "PUT SIO1SFR, DBF" instruction.

Data is read from the register by the "GET DBF, SIO1SFR" instruction.

Set or read data to or from the register in the wait status. While the wait status is released, the data may not be correctly set or read depending on the status of the shift clock pin.

Table 19-3 indicates the timing of setting and reading data and points to be noted.

Table 19-3. Reading (GET) and Writing (PUT) Data from/to Presettable Shift Register and Notes

| Status on Execution of PUT/GET |             | Status of Shift Clock Pin          | Presettable Shift Register (SIO1SFR)                                                                                                                                                                             |  |  |  |  |
|--------------------------------|-------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Wait<br>status                 | Read (GET)  | With external clock: floated       | Normally read.  Normally written.  Content of MSB is output at falling edge of shift clock when wait status is released next time (during transfer operation).  Clock  Data  MSB  PUT SIO1SFR, DBF Wait released |  |  |  |  |
|                                | Write (PUT) | With internal clock:<br>high level |                                                                                                                                                                                                                  |  |  |  |  |
| Wait                           | Read (GET)  | Low level                          | Normally read.                                                                                                                                                                                                   |  |  |  |  |
| released<br>status             |             | High level                         | Cannot be read normally. Contents of SIO1SFR are destroyed.                                                                                                                                                      |  |  |  |  |
|                                | Write (PUT) | High level                         | Normally written.  Contents of MSB are output when PUT instruction is executed.  Clock counter is not reset.  Clock  Data  MSB  PUT SIO1SFR, DBF                                                                 |  |  |  |  |
|                                |             | Low level                          | Cannot be written normally. Contents of SIO1SFR are destroyed.                                                                                                                                                   |  |  |  |  |



#### 19.7 Wait Block

The wait block controls communication of the serial interface by placing or releasing communication in or from the wait status.

The wait block is controlled by the SIO1TS flag of the serial I/O mode select register.

The following subsection 19.7.1 explains the wait operation and points to be noted.

#### 19.7.1 Wait operation and notes

In the wait status, the clock generation block and presettable shift register stop operation, and serial communication pauses.

Therefore, serial communication can be started when the wait status is released.

The wait status is released when "1" is written to the SIO1TS flag.

When "1" is written to this flag, the internal clock is output to the shift clock output pin (during master operation), and presettable shift register and clock counter start operating.

If the shift clock rises when the value of the clock counter is "8", the wait status is set. At this time, the SIO1TS flag is automatically reset to "0".

The operating status of serial communication can be checked by detecting the content of the SIO1TS flag while the wait status is released.

Therefore, data is read or set after "1" has been written to the SIO1TS flag, serial communication has been started, and then clearing of the SIO1TS flag to "0" has been detected.

If data is written to (by PUT instruction) or read from (by GET instruction) the presettable shift register while the wait status is released, the correct data may not be written or read.

For details, refer to 19.6.3 Notes on setting and reading data.

If "0" is written to the SIO1TS flag while the wait status is released, the wait status is set. This is called forced wait. When forced wait is executed, the clock counter is reset to "0".

Figure 19-5 shows an example of the wait operation.



Figure 19-5. Example of Wait Operation

When the wait status is released, the serial data is output at the next falling edge of the clock, and the wait status is released.

When the shift clock has been input eight times, the shift clock pin outputs a high level, and the clock counter and presettable shift register stop operation.

If data is written to or read from the presettable shift register while the wait status is released and the shift clock pin is high, the correct data may not be set or read.

If data is written to the presettable shift register while the wait status is released and the shift clock pin is low, the content of the MSB is output to the serial data output pin as soon as the "PUT" instruction has been executed.

If forced wait is executed while the wait status is released, the wait status is set and the clock counter is reset to "0" as soon as "0" has been written to the SIO1TS flag.



## 19.8 Using Serial Interface

Figure 19-6 illustrates the I/O block and communication method of the serial interface.

Table 19-4 indicates the operations of the serial interface in each mode.

As shown in Figure 19-6 and Table 19-4, the serial interface operates on the internal clock (master operation) or external clock (slave operation), and can perform transfer and reception on both the clocks.

The master or slave operation is selected by the SIO1CK1 and SIO1CK0 flags.

Reception or transfer is selected by the SIO1HIZ flag.

During the master operation, the internal shift clock is output from the P0B<sub>2</sub>/SCK pin. However, the P0B<sub>2</sub>/SCK pin must be set in the output port mode (P0BBIO2 flag = 1).

During the slave operation, the P0B<sub>2</sub>/ $\overline{SCK}$  pin is floated, and the serial interface waits for an external clock. At this time, the P0B<sub>2</sub>/ $\overline{SCK}$  pin must be set in the input port mode (P0BBIO2 flag = 0).

Serial data is output from the P0B<sub>1</sub>/SO pin at the falling edge of the shift clock, regardless of whether the internal clock or external clock is used. However, the P0B<sub>1</sub>/SO pin must be set in the output port mode (P0BBIO1 flag = 1) and the SIO1HIZ flag must be set.

As the serial input data, the status of the P0B $_1$ /SO pin is input to the presettable shift register at the rising edge of the shift clock, regardless of whether the internal clock or external clock is used. However, the P0B $_0$ /SI pin must be set in the input port mode (P0BBIO0 flag = 0).

The  $P0B_2/\overline{SCK}$  pin reads the "current status of the output latch" when the value output to the pin is read, and "the current status of the pin" while the wait status is released.

Paragraphs (1) through (4) below Table 19-4 show program examples of transfer and reception during master and slave operations.

Figure 19-6. I/O Block and Communication Method of Serial Interface (1/2)

I/O block





Figure 19-6. I/O Block and Communication Method of Serial Interface (2/2)

# Communication





Table 19-4. Operation of Serial Interface in Each Mode

| Operation                                                                                                                                                                   |                       | 3-Wire Serial I/O Mode                                                                                                                                                                                                                                                                                                                        |                                                                                                                               |                                                                                                                                     |                                                                                               |  |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|
| Mode                                                                                                                                                                        |                       |                                                                                                                                                                                                                                                                                                                                               | peration<br>SIO1CK0 = 0                                                                                                       | Master operation SIO1CK1 = SIO1CK0 = other than 0                                                                                   |                                                                                               |  |  |  |  |  |
|                                                                                                                                                                             |                       | Wait                                                                                                                                                                                                                                                                                                                                          | Wait released                                                                                                                 | Wait                                                                                                                                | Wait released                                                                                 |  |  |  |  |  |
| Setting<br>status of<br>each pin                                                                                                                                            | P0B <sub>2</sub> /SCK | When P0BBIO2 = 0 Floating General-purpose input port When P0BBIO2 = 1 General-purpose output port Outputs contents of output. Usually, P0BBIO2 is cleared to 0.                                                                                                                                                                               | When P0BBIO2 = 0 Floating External clock input When P0BBIO2 = 1 General-purpose output port Outputs contents of output latch. | When P0BBIO2 = 0 Floating General-purpose input port When P0BBIO2 = 1 Outputs high level. Usually, P0BBIO2 is set to 1.             | When P0BBIO2 = 0 Floating General-purpose input port When P0BBIO2 = 1 Outputs internal clock. |  |  |  |  |  |
|                                                                                                                                                                             | P0B <sub>1</sub> /SO  | When SIO1HIZ = 0                                                                                                                                                                                                                                                                                                                              | When SIO1HIZ = 1                                                                                                              | When SIO1HIZ = 0                                                                                                                    | When SIO1HIZ = 1                                                                              |  |  |  |  |  |
|                                                                                                                                                                             |                       | When P0BBIO1 = 0 General-purpose input port Floating When P0BBIO1 = 1 General-purpose output port Outputs contents of output latch.                                                                                                                                                                                                           | When P0BBIO1 = 0 General-purpose input port Floating When P0BBIO1 = 1 Outputs serial data.                                    | When P0BBIO1 = 0 General-purpose input port Floating When P0BBIO1 = 1 General-purpose output port Outputs contents of output latch. | When P0BBIO1 = 0 General-purpose input port Floating When P0BBIO1 = 1 Outputs serial data.    |  |  |  |  |  |
| P0Bo/SI When P0BBIO0 = 0 Floating Waits for external data When P0BBIO0 = 1 General-purpose output port. Outputs contents of output latch. Usually, P0BBIO0 is cleared to 0. |                       |                                                                                                                                                                                                                                                                                                                                               |                                                                                                                               |                                                                                                                                     |                                                                                               |  |  |  |  |  |
| Operation of clock counter                                                                                                                                                  |                       | Incremented at falling edge of SCK pin.                                                                                                                                                                                                                                                                                                       |                                                                                                                               |                                                                                                                                     |                                                                                               |  |  |  |  |  |
| Operation of presettable shift register (SIO1SFR)                                                                                                                           |                       | Output  When SIO1HIZ = 1  Shifts data from MSB and outputs it to SO <sub>2</sub> pin at falling edge of SCK pin.  When SIO1HIZ = 0  Does not output data.  Input  Shifts data of SI pin from LSB and inputs it at rising edge of SCK pin regardless of P0BBIO0.  However, the contents of output latch are output to SI pin when P0BBIO0 = 1. |                                                                                                                               |                                                                                                                                     |                                                                                               |  |  |  |  |  |
| Wait operation                                                                                                                                                              |                       | Serial communication is started when "1" is written to SIO1TS.  SIO1TS is reset to "0" at rising edge of shift clock when value of clock counter is "8".  For operation of each pin, refer to above.                                                                                                                                          |                                                                                                                               |                                                                                                                                     |                                                                                               |  |  |  |  |  |



### (1) Program example of serial interface (in master transfer mode)

**Example** To transfer 2-byte data "A596H"

```
SCKBIO
                  FLG
                            P0BBIO2
        SOBIO
                  FLG
                            P0BBI01
                                           ; Sets transfer data
        MOV
                  DBF1,
                           #0AH
                          #5
        MOV
                  DBF0,
        PUT
                  SIO1SFR, DBF
        SET2
                  SCKBIO, SOBIO
        INITFLG SIO1TS, SIO1HIZ, NOT SIO1CK1, SIO1CK0
                                           ; Releases wait, and outputs serial data
                                           ; Master (fsc = 75 \text{ kHz})
LOOP1:
        SKF1
                  SIO1TS
                                           ; Wait until wait status is released
                  LOOP1
        BR
        MOV
                  DBF1, #9
                                           ; Sets transfer data
        MOV
                  DBF0, #6
                  SIO1SFR, DBF
        PUT
                  SIO1TS
                                           ; Releases wait
        SET1
LOOP2:
        SKF1
                  SIO1TS
                                           ; Waits until wait status is released
                  LOOP2
        BR
```

#### (2) Program example of serial interface (in master reception mode)

Example To receive 2-byte data and store it to addresses 00H through 03H of BANK0

```
SCKBIO
                  FLG
                            P0BBI02
        SIBIO
                  FLG
                            P0BBIO0
                            0.00H
                                            ; Stores high-order 4 bits of first byte
        DATA1H MEM
        DATA1L
                            0.01H
                                            ; Stores low-order 4 bits of first byte
                  MEM
                                            ; Stores high-order 4 bits of second byte
                            0.02H
        DATA2H
                  MEM
        DATA2L
                            0.03H
                                            ; Stores low-order 4 bits of second byte
                  MEM
        INITFLG SCKBIO, NOT SIBIO
         INITFLG SIO1TS, NOT SIO1HIZ, SIO1CK1, SIO1CK0
                                            ; Releases wait, and does not output serial data
                                            ; Master (fsc = 450 \text{ kHz})
LOOP1:
         SKF1
                  SIO1TS
                                            ; Wait until wait status is released
        BR
                  LOOP1
                  DBF, SIO1SFR
                                            ; Reads receive data
        GET
                                            ; Stores read data
                  DATA1H, DBF1
        ST
        ST
                  DATA1L, DBF0
                                            ; Releases wait
        SET1
                  SIO1TS
LOOP2:
                                            ; Waits until wait status is released
        SKF1
                  SIO1TS
        BR
                  LOOP2
        GET
                  DBF, SIO1SFR
                                            ; Reads receive data
        ST
                  DATA2H, DBF1
                                            ; Stores read data
         ST
                   DATA2L, DBF0
         :
```

### (3) Program example of serial interface (in slave transfer mode)

Example To transfer 2-byte data "A596H"

```
SCKBIO
                 FLG
                           P0BBI02
        SOBIO
                  FLG
                           P0BBI01
        INITFLG NOT SCKBIO, SOBIO
                                          ; Sets transfer data
        MOV
                  DBF1, #0AH
        MOV
                  DBF0, #5
                  SIO1SFR, DBF
        PUT
        INITFLG SIO1TS, SIO1HIZ, NOT SIO1CK1, NOT SIO1CK0
                                          ; Releases wait, outputs serial data, slave
LOOP1:
                  SIO1TS
                                          ; Wait until wait status is released
        SKF1
                  LOOP1
        BR
                                          ; Sets transfer data
                 DBF1, #9
        MOV
        MOV
                 DBF0, #6
        PUT
                  SIO1SFR, DBF
        SET1
                  SIO1TS
                                          : Releases wait
LOOP2:
        SKF1
                  SIO1TS
                                          ; Waits until wait status is released
        BR
                  LOOP2
        :
```

## (4) Program example of serial interface (in slave reception mode)

Example To receive 2-byte data and store it to addresses 00H through 03H of BANK0

```
SCKBIO
                 FLG
                            P0BBI02
        SIBIO
                  FLG
                            P0BBIO0
                            0.00H
                                          ; Stores high-order 4 bits of first byte
        DATA1H MEM
                                          ; Stores low-order 4 bits of first byte
                            0.01H
        DATA1L
                 MEM
                                           ; Stores high-order 4 bits of second byte
        DATA2H
                 MEM
                            0.02H
                                           ; Stores low-order 4 bits of second byte
                            0.03H
        DATA2L MEM
                  SCKBIO, SIBIO
        CLR2
        INITFLG SIO1TS, NOT SIO1HIZ, NOT SIO1CK1, NOT SIO1CK0
                                           ; Releases wait, does not output serial
                                           ; data, slave
LOOP1:
        SKF1
                                           ; Wait until wait status is released
                  SIO1TS
                  LOOP1
        BR
                  DBF, SIO1SFR
                                           ; Reads receive data
        GET
                  DATA1H, DBF1
        ST
                                           : Stores read data
        ST
                  DATA1L, DBF0
                  SIO1TS
                                          : Releases wait
        SET1
LOOP2:
                  SIO1TS
                                          ; Waits until wait status is released
        SKF1
        BR
                  LOOP2
                  DBF, SIO1SFR
                                          ; Reads receive data
        GET
        ST
                  DATA2H, DBF1
                                           ; Stores read data
        ST
                  DATA2L, DBF0
        :
```



#### 19.9 Status of Serial Interface on Reset

## 19.9.1 On power-ON reset

All of the pins P0B<sub>2</sub>/SCK through P0B<sub>0</sub>/SI are set in the general-purpose input port mode (floating output). The value of the presettable shift register is undefined.

## 19.9.2 On execution of clock stop instruction

All of the pins P0B<sub>2</sub>/SCK through P0B<sub>0</sub>/SI are set in the general-purpose input port mode (floating output). The presettable shift register retains the previous value.

## 19.9.3 On CE reset

All of the pins  $P0B_2/\overline{SCK}$  through  $P0B_0/SI$  are set in the general-purpose input port mode (floating output). The presettable shift register retains the previous value.

#### 19.9.4 In halt status

The I/O pins retain the current status.

If the internal clock is used (master operation) at this time, the clock is not output after the "HALT" instruction has been executed.

To use the internal clock, therefore, the "HALT" instruction must be executed after communication has been completed.

If an external clock is forcibly input, the serial interface functions even when the internal clock is used.

If the external clock is used (slave operation), the operation continues even when the "HALT" instruction has been executed.

## 20. FREQUENCY COUNTER (FC)

The frequency counter (FC) is used to count the intermediate frequency (IF) of a tuner.

# 20.1 Configuration of Frequency Counter

Figure 20-1 shows the block diagram of the frequency counter.

As shown in the figure, the IF counter consists of an input select block, gate time control block, start/stop control block, and count block.

Figure 20-1. Block Diagram of Frequency Counter



## 20.2 Functional Outline of Frequency Counter

The frequency counter has an IF counter function that is used to count the frequency of an externally input signal.

The IF counter function is to count the frequency input to the P1D<sub>3</sub>/FMIFC or P1D<sub>2</sub>/AMIFC pin by using a 16-bit counter at fixed time intervals (1 ms, 4 ms, 8 ms, or open).

The following subsections 20.2.1 through 20.2.4 outline each function block of the frequency counter.

Because the frequency counter shares the hardware with the BEEP function explained in **18. BEEP OUTPUT**, it cannot be used with the BEEP function at the same time. For details, refer to **20.7 Notes on Using Frequency Counter**.

## 20.2.1 IF counter input select block

The IF counter input select block specifies whether the P1D<sub>3</sub>/FMIFC and P1D<sub>2</sub>/AMIFC pins are used as general-purpose input port pins or IF counter pins.

This selection is made by the IF counter mode select register (RF address 12H).

For details, refer to 20.3.



#### 20.2.2 Gate time control block

The gate time control block controls the time during which the frequency is counted by the IF counter mode select register.

The IF counter mode select register sets the internal gate time (1 ms, 4 ms, 8 ms, or open) to count the frequency applied to the P1D<sub>3</sub>/FMIFC or P1D<sub>2</sub>/AMIFC pin.

For details, refer to 20.3.

## 20.2.3 Start/stop control block

The start/stop control block starts or stops the frequency counter.

Starting or stopping the frequency counter is controlled by the IF counter control register (RF address 23H) and IF counter gate judge register (RF address 04H).

For details, refer to 20.4.

## 20.2.4 IF counter

The input frequency is counted by a 16-bit binary counter.

The count value is read by the IF counter data register (IFC: peripheral address 43H) via the data buffer. For details, refer to **20.4**.

# 20.3 Input Select Block and Gate Time Control Block

## 20.3.1 Configuration of input select block and gate time control block

Figure 20-2 shows the configuration of the input select block and gate time control block.

Figure 20-2. Configuration of Input Select Block and Gate Time Control Block





## 20.3.2 Function of input select block

The input select block selects whether the P1D<sub>3</sub>/FMIFIC and P1D<sub>2</sub>/AMIFC pins are used as general-purpose output port pins or frequency counter pins.

This selection is made by the IFCMD1 and IFCMD0 flags of the IF counter mode select register (refer to **20.3.4**).

## 20.3.3 Function of gate time control block

The gate time control block sets a gate time (count time).

The gate time is set by the IFCCK1 and IFCCK0 flags of the IF counter mode select register (refer to 20.3.4).

## 20.3.4 Configuration and function of IF count mode select register

The IF counter mode select register selects the IF counter function and gate time.

The configuration and function of this register are illustrated below.

Because the frequency counter is shared with the BEEP function, this register is also used to select the BEEP output.



Caution The IF counter function and BEEP function cannot be used at the same time.



## 20.4 Start/Stop Control Block and IF Counter

## 20.4.1 Configuration of start/stop control block and counter

Figure 20-3 shows the configuration of the start/stop control block and counter.

Data buffer (DBF) Control register Control register 0EH 0FH Address Address Address 0CH 0DH b<sub>2</sub> b<sub>1</sub> b<sub>2</sub> b<sub>1</sub>  $b_0$ DBF3 DBF2 DBF1 DBF0 bз  $b_0$ bз Symbol 0 Flag 0 0 0 Flag 0 Data L S B S symbol symbol С C S T R T C R Ğ E ō S T T 16 Peripheral address 43H IF counter data register (IFC) 16 **RES** Gate signal from IF counter Start/stop input select block (16 bits) High-order 6 bits are shared with BEEP function block.

Figure 20-3. Configuration of Start/Stop Control Block and Counter

## 20.4.2 Function of start/stop control block

The start/stop control block detects the start and end of counting by the frequency counter.

The counting is started by using the IFCSTRT flag of the IF counter control register.

To detect the end of the counting, the IFCGOSTT flag of the IF counter gate judge register is used.

The following subsections 20.4.6 and 20.4.7 explain the configuration and functions of the IF counter control register and IF counter gate judge register.

## 20.4.3 Gate operation of IF counter

## (1) When 1, 4, or 8 ms is selected as gate time

The gate is opened for 1, 4, or 8 ms since the internal 1-kHz signal has risen after the IFCSTRT flag was set to "1", as shown below.

While this gate is open, the frequency input from the pin is counted by the 16-bit counter.

When the gate is closed, the IFCGOSTT flag is reset.

The IFCGOSTT flag is automatically set to "1" when the IFCSTRT flag has been set.





#### (2) When "open" is selected as gate time

As soon as it has been specified by the IFCCK1 and IFCCK0 flags that the gate is "opened", the gate is opened. If counting is started by the IFCSTRT flag while the gate is open, the gate is closed after an undefined time. Therefore, do not set the IFCSTRT flag to "1" when selecting "open" as the gate time. However, the counter can be reset by the IFCRES flag.



When "open" is selected as the gate time, the gate can be opened or closed in two ways as explained in (a) and (b) below.

## (a) Set gate time other than "open" by IFCCK1 and IFCCK0 flags



## (b) Unselect pin used by using IFCMD1 and IFCMD0 flags

In this case, the gate is remains open, and counting is stopped by inhibiting input from the pin.



### 20.4.4 Function and operation of 16-bit counter

The 16-bit counter counts up the frequency input within the specified gate time.

This counter is reset by writing "1" to the IFCRES flag of the IF counter control register.

When the 16-bit counter counts up to FFFFH, it is cleared to 0000H and continues counting when the next input is applied.

Because the high-order 6 bits of this counter are shared with the BEEP function, the frequency counter and BEEP function cannot be used at the same time.

The function of the IF counter is to count the frequency input to the P1D<sub>3</sub>/FMIFC or P1D<sub>2</sub>/AMIFC pin while the gate is open.

Note, however, that the frequency input to the P1D3/FMIFC pin is divided by two and is counted.

The relation between count value "x (HEX)" and input frequency (ffmifc or famifc) is as follows.

**FMIFC** 

$$f_{\text{FMIFC}} = \frac{x \text{ (DEC)}}{t_{\text{GATE}}} \times 2 \text{ (kHz)}$$
  $t_{\text{GATE}} = \text{gate time (1, 4, or 8 ms)}$ 

**AMIFC** 

$$f_{AMIFC} = \frac{x (DEC)}{t_{GATE}}$$
 (kHz)  $t_{GATE} = gate time (1, 4, or 8 ms)$ 

The value of the IF counter data register is read via the data buffer.

The following subsection 20.4.5 explains the configuration and function of the IF counter data register.



## 20.4.5 Configuration and function of IF counter data register (IFC)

The configuration and function of the IF counter data register are illustrated below.

The IF counter data register reads the count value of the frequency counter.

This register is cleared to 0000H at the next input when its value has reached FFFFH, and continues counting.



The high-order 6 bits of the IF counter are shared with the BEEP function.

Therefore, the frequency counter function and BEEP function cannot be used at the same time.

For details, refer to 20.7 Notes on Using Frequency Counter.

## 20.4.6 Configuration and function of IF counter control register

The IF counter control register starts the frequency counter (IF counter) function and controls resetting of the 16-bit counter.

The configuration and function of this register are illustrated below.



The IF counter control register is controlled by writing the contents of the window register by using the "POKE" instruction.

When the contents of this register are read to the window register by the "PEEK" instruction, "0" is read. If either of the IFCRES or IFCSTRT flag is set by using the assembler (AS17K) embedded macroinstruction SETn, the flag that is not set becomes "undefined", and an error occurs. For details, refer to 20.7.3 Notes on using embedded macroinstruction SETn to IFCRES and IFCSTRT flags.



# 20.4.7 Configuration and function of IF counter gate judge register

The IF counter gate judge register detects the opening and closing of the gate of the IF counter.

The configuration and function of this register are illustrated below.



Caution Do not read the contents of the IF counter data register (IFC) to the data buffer while the IFCGOSTT flag is set to 1 (i.e., while the gate is open).

# 20.5 Using IF Counter Function

The following subsections 20.5.1 through 20.5.3 explain how to use the hardware of the IF counter function, program example, and count error.

### 20.5.1 Using hardware of IF counter

Figure 20-4 shows the block diagram illustrating how the P1D<sub>3</sub>/FMIFC and P1D<sub>2</sub>/AMIFC pins are used.

Table 20-1 shows the range of the frequencies that can be input to the P1D<sub>3</sub>/FMIFC and P1D<sub>2</sub>/AMIFC pins.

Because the input pins of the IF counter have an internal amplifier, cut off the DC component of the input signal by using capacitor C as shown in Figure 20-4.

When the P1D<sub>3</sub>/FMIFC or P1D<sub>2</sub>/AMIFC pin is selected as the IF counter pin, switch SW turns ON, applying a voltage of about  $1/2V_{DD}$  to each pin.

If the voltage has not risen to a sufficient intermediate level at this time, the AC amplifier does not operate normally, and consequently, the IF counter does not correctly operate.

Therefore, make sure that a sufficiently long wait time elapses from the time each pin is selected as an IF counter until counting is started.

Figure 20-4. Function of Each IF Counter Pin



Table 20-1. Input Frequency Range of IF Counter

| Input Pin               | Input Frequency<br>(MHz) | Input Amplitude<br>(V <sub>p-p</sub> ) |  |  |  |  |  |  |
|-------------------------|--------------------------|----------------------------------------|--|--|--|--|--|--|
| P1D <sub>3</sub> /FMIFC | 5-15                     | 0.3                                    |  |  |  |  |  |  |
|                         | 10.5-10.9                | 0.06                                   |  |  |  |  |  |  |
| P1D <sub>2</sub> /AMIFC | 0.1-1                    | 0.3                                    |  |  |  |  |  |  |
|                         | 0.44-0.46                | 0.05                                   |  |  |  |  |  |  |



## 20.5.2 Program example of IF counter function

A program example of the IF counter function is shown below.

As shown in this example, wait time must elapse after an instruction that selects the P1D<sub>3</sub>/FMIFC or P1D<sub>2</sub>/AMIFC pin as the IF counter pin has been executed before counting is started.

This is because the internal AC amplifier may not operate normally immediately after each pin has been selected, as explained in 20.5.1.

## Example To count frequency on P1D<sub>3</sub>/FMIFC pin (gate time: 8 ms)



Note Refer to 20.7.3 Notes on using embedded macroinstruction SETn to IFCRES and IFCSTRT flags.

#### 20.5.3 Error of IF counter

The IF counter may have a gate time error and a count error.

These errors are explained in (1) and (2) below.

# (1) Error of gate time

The gate time of the IF counter is created by dividing the 4.5-MHz system clock.

Therefore, if the system clock deviates "+x" ppm, the gate time deviates "-x" ppm.

# (2) Count error

The IF counter counts the frequency at the rising edge of an input signal.

If a high level is input to the pin when the gate is opened, therefore, one excess pulse is counted.

However, counting is not performed because of the status of the pin when the gate is closed.

Therefore, a count error of "+1, -0" may occur.

#### 20.6 Status on Reset

## 20.6.1 On power-ON reset

The P1D<sub>3</sub>/FMIFC and P1D<sub>2</sub>/AMIFC pins are set in the general-purpose input port mode.

#### 20.6.2 On execution of clock stop instruction

The P1D<sub>3</sub>/FMIFC and P1D<sub>2</sub>/AMIFC pins are set in the general-purpose input port mode.

#### 20.6.3 On CE reset

The P1D<sub>3</sub>/FMIFC and P1D<sub>2</sub>/AMIFC pins retain the previous status.

#### 20.6.4 In halt status

The P1D3/FMIFC and P1D2/AMIFC pins retain the status immediately before the halt status is set.

To release the halt status by using the interrupt of the frequency counter, the following point must be noted.

Caution If the "HALT" instruction is executed after counting has been started by the IFCSTRT flag and before the gate is actually opened, the gate will not be opened.

Therefore, wait at least 1 ms after starting counting before executing the "HALT" instruction.

Figure 20-5 shows the gate operation when the "HALT" instruction is executed.

Because the closing of the gate cannot be detected unless the gate is opened, the interrupt request is not issued. If interrupts other than that of the IF counter are not enabled with halt release conditions other than the interrupt not specified, the HALT status will not be released.

Figure 20-5. Gate Operation When "HALT" Instruction Is Used





# 20.7 Notes on Using Frequency Counter

The frequency counter shares its hardware with the BEEP function explained earlier.

Therefore, the BEEP function and frequency counter cannot be used at the same time.

If the data of the IF counter mode select register and IF counter data register are manipulated while the BEEP function is used, the operation explained in 20.7.1 is performed.

If the BEEP output software macro is executed when the frequency counter is used, the operation explained in 20.7.2 is performed.

The assembler embedded macroinstruction SETn cannot be used to manipulate the IFCRES and IFCSTRT flags, as explained in 20.4.6. This is explained in more detail in 20.7.3.

#### 20.7.1 When BEEP output is used

# (1) When IFCMD1 and IFCMD0 flags of IF counter mode select register are manipulated

If a value other than "0" is written to the IFCMD1 and IFCMD0 flags, the P1B<sub>0</sub>/BEEP pin retain the current output level, and stops the BEEP output.

When both the IFCMD1 and IFCMD0 flags are reset to "0" again, the BEEP output is started.

# (2) When IF counter data register is manipulated

The BEEP output is not affected even if a read (GET) or write (PUT) instruction is executed.

When the IF counter data register is read, an "undefined" value is read. Nothing is changed even if data is written to the register.

Note, however, that the IF counter data register is a read-only peripheral register. Do not write data to this register. If the write instruction "PUT IFC, DBF" is executed, the 17 series assembler outputs an error.

#### 20.7.2 When frequency counter is used

If the BEEP output software macro is executed while the frequency counter is used, the frequency counter is forcibly stopped, and the BEEP output is started. At this time, the contents of the window register (WR) and data buffer (DBF) are destroyed. To operate the frequency counter again, once stop the BEEP output by using the BEEPOFF macro, and start counting from the beginning.



## 20.7.3 Notes on using embedded macroinstruction SETn to IFCRES and IFCSTRT flags

Because the IFCRES and IFCSTRT flags are in a write-only register, an "undefined" value is read if these flags are read.

If either of these flags is set by assembler (AS17K) embedded macroinstruction "SETn", an "undefined" value is written to the other flag.

```
PEEK WR,.MF.IFCRES SHR4 ; Value of WR is "undefined" at this time.
OR WR,#.DF.IFCRES AND 0FH ; Only bit 0 of WR is set.
POKE .MF.IFCRES SHR 4, WR ; Undefined value is written to IFCSTRT (bit 1).
```

If the SETn instruction is executed to the IFCRES and IFCSTRT flag, therefore, the assembler outputs an error.

Therefore, use macro definition to manipulate the IFCRES and IFCSTRT flags as follows.

```
IFCW MEM 0.0A3H
;
IFC_RES_AND_START
                        MACR 0
      MOV
              WR,
                   #0011B
      POKE
              IFCW, WR
ENDM
;
IFC_RES
                        MACR0
                   #0001B
      VOM
              WR,
      POKE
              IFCW, WR
ENDM
IFC_START
                        MACR0
      MOV
              WR,
                   #0010B
      POKE
              IFCW, WR
ENDM
```

The above macroinstruction is supplied with the device file as "IFCSET.LIB" file and "D17016.INC/D17017.INC" file.

Therefore, the above macroinstruction can be used as is by INCLUDEing these files on the source program. For how to use each file, refer to **AS17016 Device File User's Manual**.



#### 21. LCD CONTROLLER/DRIVER

The LCD (Liquid Crystal Display) controller/driver can display an LCD of up to 60 dots by outputting segment and common signals in combination.

# 21.1 Configuration of LCD Controller/Driver

Figure 21-1 shows the block diagram of the LCD controller/driver.

As shown in the figure, the LCD controller/driver consists of a common signal output timing control block, segment signal/key source signal output timing control block, segment signal/output port select block, LCD segment register, and key source signal output control block.

The following section 21.2 outlines the function of each block.

Figure 21-1. Block Diagram of LCD Controller/Driver



#### 21.2 Functional Outline of LCD Controller/Driver

The LCD controller/driver can display up to 60 dots by using the combination of common signal output pins (COM<sub>1</sub> and COM<sub>0</sub>) and segment signal output pins (LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>0</sub>/KS<sub>0</sub>).

Figure 21-2 shows the relation among common signal output pins, segment signal output pins, and display dots.

As shown in this figure, two dots at the intersections between one segment line with COM<sub>1</sub> and COM<sub>0</sub> pins. The driving mode is 1/2 duty, 1/2 bias, and the drive voltage is supply voltage V<sub>DD</sub>.

The segment signal output pins (LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>22</sub>/P0E<sub>0</sub>) pins can also be used as general-purpose output port pins.

When these pins are used as general-purpose output port pins, ports 0F (LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>26</sub>/P0F<sub>0</sub>) and 0E (LCD<sub>25</sub>/P0E<sub>3</sub> through LCD<sub>22</sub>/P0E<sub>0</sub>) can be independently used.

Of the segment signal output pins, the  $LCD_{15}/KS_{15}$  through  $LCD_0/KS_0$  pins are also used as key source signal output pins.

The key source signals and LCD segment signals are output by means of time-division multiplexing.

For the details on the general-purpose output ports, refer to 15. GENERAL-PURPOSE PORT.

For the details on the key source signals, refer to 22. KEY SOURCE CONTROLLER/DECODER.

The following subsections 21.2.1 through 21.2.5 outlines the function of each block of the LCD controller/driver.

Figure 21-2. Common Signal Output, Segment Signal Output, and Display Dot



## 21.2.1 LCD segment register

The LCD segment register sets dot data that is used to turn ON/OFF the LCD.

Because this register is mapped on the data memory, it can be controlled by any data memory manipulation instruction.

When the segment signal output pins are used as general-purpose output port pins, this registers sets output data.

For details, refer to 21.3.



#### 21.2.2 Common signal output timing control block

The common signal output timing control block controls the common signal output timing of the COM1 and COM0 pins.

These pins output a low level when the LCD is not displayed.

Whether the LCD is displayed or not is selected by the LCD mode select register (RF address 10H).

For details, refer to 21.4.

#### 21.2.3 Segment signal/key source signal output timing control block

The segment signal/key source signal output timing control block controls the segment signal output timing of the LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins.

These pins output a low level when the LCD is not displayed.

Whether the LCD is displayed or not is selected by the LCD mode select register.

The segment signal/key source signal output timing control block controls the timing of the segment and key source signals output from the LCD<sub>15</sub>/KS<sub>15</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins.

Whether the key source signals are used or not is selected by the LCD mode select register.

For details, refer to 21.4.

## 21.2.4 Segment signal/general-purpose port select block

The segment signal/general-purpose port select block selects whether each segment signal output pin is used for LCD display (to output a segment signal) or as a general-purpose output port pin.

This selection is made by using the software macro supplied with the device file.

For details, refer to 21.4.

## 21.2.5 Key source signal output control block

The key source signal output control block sets the key source output data that are output from the LCD<sub>15</sub>/ KS<sub>15</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins and detects key input timing.

The key source signal output data are set by the key source data register (KSR: peripheral address 42H) via the data buffer.

To use the key source signals, the P0D3/ADC5 through P0D0/ADC2 pins are used as key input pins.

For details, refer to 22. KEY SOURCE CONTROLLER/DECODER.

# 21.3 LCD Segment Register

The LCD segment register specifies whether each dot on the LCD is turned ON/OFF.

# 21.3.1 Configuration of LCD segment register

Figure 21-3 shows the location of the LCD segment register on the data memory.

Figure 21-4 shows the configuration of the LCD segment register.

Figure 21-3. Location of LCD Segment Register on Data Memory



**Note** BANK3 is not provided on the  $\mu$ PD17016.

Figure 21-4. Configuration of LCD Segment Register





## 21.3.2 Function of LCD segment register

Figure 21-5 shows the relation of 1 nibble (4 bits) of the LCD segment register and LCD display dots.

As shown in this figure, 1 nibble of the LCD segment register can set display data (ON/OFF data) of 4 dots.

The LCD display dot corresponding to a bit that is set to "1" is turned ON, and the dot corresponding to a bit that is reset to "0" is turned OFF.

The LCD segment register also sets output data when the segment signal output pins are used as output port pins.

Figure 21-6 shows the relation between each LCD segment register and LCD display dots that are turned ON/OFF.

Figure 21-5. Relation of 1 Nibble of LCD Segment Register and LCD Display Dots



[MEMO]



Figure 21-6. Relation among LCD Display Dots, Ports 0E and 0F, Key Source Output, and Each Data Setting Register (1/2)



**KSR** (42H)  $b_{15} b_{14} b_{13} b_{12} b_{11} b_{10} b_{9} b_{8} b_{7} b_{6} b_{5} b_{4} b_{3} b_{2} b_{1} b_{0} \\$ K S 15 K S 14 K S 13 K S 12 K S 11 K S 10 K S 9 K S 8 K S 4 K S 3 K S 1 K S 0 Correspondence Ьз Ьз Ьз Ьз Ьз b<sub>1</sub> Ьз b<sub>1</sub> of segment register bit b<sub>2</sub> b<sub>0</sub> b<sub>2</sub> b<sub>2</sub> b<sub>0</sub>  $b_2 \\$ b<sub>0</sub> b<sub>0</sub>  $b_2$  $b_0$  $b_2$  $b_0$  $b_2$  $b_0$  $b_2$  $b_0$ L C D 8 L C D L C D 4 L C D 15 L C D L C D L C D ° L C D L C D 9 L C D 5 L C D L C D L C D 3 L C D L C D (59)(60)(61) (62)(63)(64)(65)(66)(67)(68)(69)(70)(71) (72)(73)(74) $b_3 \ | \ b_2 \ | \ b_1 \ | \ b_0 \ | \ b_3 \ | \ b_2 \ | \ b_1 \ | \ b_0 \ | \ b_3 \ | \ b_2 \ | \ b_1 \ | \ b_0 \ | \ b_3 \ | \ b_2 \ | \ b_1 \ | \ b_0$ LCDD7 LCDD6 LCDD5 LCDD4 LCDD3 LCDD2 LCDD1 LCDD0 (67H) (66H) (65H) (64H) (63H) (62H) (61H) (60H)

Figure 21-6. Relation among LCD Display Dots, Ports 0E and 0F, Key Source Output, and Each Data Setting Register (2/2)



# 21.4 Output Timing Control Blocks and Segment/Port Select Block

# 21.4.1 Configuration of output timing control blocks and segment/port select block

Figure 21-7 shows the configuration of the common signal and segment signal/key source signal output timing control block and segment signal/general-purpose output port select block.

Control register Address 10H Bit bз  $b_2$ L Flag 0 0 K S E N CDEN symbol Key source data register Segment signal/ key source signal LCD<sub>0</sub>/KS<sub>0</sub> bo LCD segment timing control register LCD<sub>15</sub>/KS<sub>15</sub> C Segment signal bo LCD segment timing control b₁ register LCD<sub>21</sub> LCD<sub>22</sub>/P0E<sub>0</sub> LCD<sub>25</sub>/P0E<sub>3</sub> LCD<sub>26</sub>/P0F<sub>0</sub> C  $V_{DD}$ 1 0 LCD<sub>28</sub>/P0F<sub>2</sub> bo LCD segment Segment signal timing control b₁ register Port data 10 LCD<sub>29</sub>/P0F<sub>3</sub> C b2 LCD segment Segment signal timing control b₃ register Setting by Basic clock for software macro timing control  $V_{DD}$ COM<sub>0</sub> Common signal timing control COM<sub>1</sub> O

Figure 21-7. Configuration of Timing Control Blocks and Port Select Block



#### 21.4.2 Function of segment signal/general-purpose output port select block

The segment signal/general-purpose output port select block specifies whether each pin is used as a segment signal output pin or a general-purpose output port pin, by using the software macro supplied with the device file (refer to Table 21-1. Software Macros Setting Ports (P0E and P0F)).

For the details on the general-purpose output port, refer to 15. GENERAL-PURPOSE PORT.

Table 21-1. Software Macros Setting Ports (P0E and P0F)

| Function                                                                                                                                                                                                                              | Macro Format         |  |  |  |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|--|--|--|--|--|
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as general-purpose output port                                                                                                                     | SET1_P0EON           |  |  |  |  |  |
| Uses LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as general-purpose output port                                                                                                                     | SET1_P0FON           |  |  |  |  |  |
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as general-purpose output port                                   | SET2_P0EON_P0FON     |  |  |  |  |  |
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as LCD segment signal output pins                                                                                                                  | CLR1_P0EON           |  |  |  |  |  |
| Uses LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as LCD segment signal output pins                                                                                                                  | CLR1_P0FON           |  |  |  |  |  |
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as LCD segment signal output pins                                     | CLR2_P0EON_P0FON     |  |  |  |  |  |
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as LCD segment signal output pins and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as general-purpose output port | INIT_NOT_P0EON_P0FON |  |  |  |  |  |
| Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as general-purpose output port and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as LCD segment signal output pins | INIT_P0EON_NOT_P0FON |  |  |  |  |  |

Caution If the above macros are used, the contents of the window register are destroyed. If the above macros are immediately follow an embedded macro instruction, an "object error" occurs when the source file is assembled and loaded to the in-circuit emulator. If an embedded macro is used before the above macros, insert a comment statement in between them.

#### 21.4.3 Functions of output timing control blocks

The output timing control blocks control the timing of the common and segment signals for LCD display and the timing of the key source and segment signals when the key source controller/decoder is used.

The common and segment signals are output when the LCDEN flag of the LCD mode select register is "1". In other words, all the LCD display dots can be turned OFF by the LCDEN flag.

When all the LCD display dots have been turned OFF, the common and segment signals output a low level.

The key source signals are output when the KSEN flag of the LCD mode select register is "1".

Therefore, use of the key source signal can be specified by the KSEN flag.

21.4.4 explains the configuration and function of the LCD mode select register.

21.4.5 shows the output waveforms of the common and segment signals.

For the details on the key source controller/decoder, refer to 22. KEY SOURCE CONTROLLER/DECODER.



# 21.4.4 Configuration and function of LCD mode select register

The LCD mode select register turns ON/OFF all the LCD display dots, and specifies output of the key source signals.

The configuration and function of this register are illustrated below.



#### 21.4.5 Output Waveforms of Common and Segment Signals

Figures 21-8 and 21-9 show the output waveforms of the common and segment signals.

Figure 21-8 shows the output waveform with the key source signals not output, and Figure 21-9 shows the output waveform with the key source signals output.

As shown in Figure 21-8, the LCD driver outputs signals with a frame frequency of 125 Hz at 1/2 duty, 1/2 bias (voltage average mode).

As the common signals, three levels of voltages (0, 1/2 V<sub>DD</sub>, and V<sub>DD</sub>) each having a phase difference of 1/4 from the others are output from the COM<sub>1</sub> and COM<sub>0</sub> pins.

Therefore, voltages in a range of 1/2 VDD ± 1/2 VDD are output. This display mode is called 1/2 bias drive mode.

As the segment signals, two levels (0, V<sub>DD</sub>) of voltages each having a phase corresponding to a display dot are output from each segment signal output pin.

Because two display dots (A and B) are turned ON/OFF by one segment pin as shown in Figure 21-8, four types of phases <1> through <4> shown in Figure 21-8 are output by combination of dots A and B, and ON and OFF.

Dots A and B are turned ON when the potential difference between the common and segment signals reaches

The duty factor at which each of dots A and B is turned ON is 1/2, and the frequency of the LCD clock is 250 Hz.

This display mode is called 1/2 duty drive mode, and the frame frequency is 125 Hz.



Figure 21-8. Output Waveforms of Common and Segment Signals (with key source signals not output)



# **Common signals**





Figure 21-9. Output Waveforms of Common and Segment Signals (with key source signals output)



# **Common signals**



# Each segment pin (pin outputting "1" as key source)



# Each segment pin (pin outputting "0" as key source)





# 21.5 Using LCD Controller/Driver

Figure 21-10 shows an example of wiring an LCD panel.

An example of a program that turns ON a 7-segment LCD panel by using the LCD<sub>0</sub> through LCD<sub>3</sub> pins as shown in Figure 21-10 is shown below.

```
Example
      PMN0
                                ; Preset memory number and BK data storage area
               MEM
                     0.01H
      СН
               FLG
                     DBF0.1
                                ; Symbol definition of least significant bit of DBF as "CH" display flag
  LCDDATA:
                                ; Display table data
                               b3 b2 b1 b0 b3 b2 b1 b0
                                                      ; Corresponds to LCD segment register
  ;
                                fbegdca-
                                                      ; Corresponds to LCD group register
               0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 B
                                                      ; BLANK
      DW
      DW
               0 0 0 0 0 0 0 0 0 1 0 0 0 1 0 0 B
                                                      ; 1
      DW
               0 0 0 0 0 0 0 0 0 1 1 1 1 1 0 1 0 B
                                                      : 2
               0 0 0 0 0 0 0 0 0 1 0 1 1 1 1 0 B
                                                      ; 3
      DW
                                                      ; 4
      DW
               0 0 0 0 0 0 0 0 1 1 0 1 0 1 0 0 B
               0 0 0 0 0 0 0 0 1 0 0 1 1 1 1 0 B
                                                      : 5
      DW
               0 0 0 0 0 0 0 0 1 0 1 1 1 1 1 0 B
                                                      : 6
      DW
               0 0 0 0 0 0 0 0 1 1 0 0 0 1 1 0 B
                                                      ; 7
      DW
                                                      ; 8
               0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 0 B
      DW
      DW
               0 0 0 0 0 0 0 0 1 1 0 1 1 1 1 0 B
                                                      ; 9
               0 0 0 0 0 0 0 0 1 1 1 1 1 1 0 1 0 B
                                                      ; A
      DW
               0 0 0 0 0 0 0 0 1 1 1 1 1 1 1 0 B
                                                      ; B
      DW
                                                      ; C
      DW
               0 0 0 0 0 0 0 0 1 0 1 0 1 0 1 0 B
                                                      ; D
      DW
               0 0 0 0 0 0 0 0 1 1 1 0 1 1 1 0 B
      DW
               0 0 0 0 0 0 0 0 1 0 1 1 1 0 1 0 B
                                                      ; E
                                                      ; F
      DW
               0 0 0 0 0 0 0 0 1 0 1 1 0 0 1 0 B
                              ; Software macro
      CLR2_P0EON_P0FON
      MOV
               RPL, #1110B
      MOV
               AR3, #.DL.LCDDATA SHR 12 AND
                                                  0FH
      MOV
               AR2, #.DL.LCDDATA SHR 8
                                              AND
                                                   0FH
      MOV
               AR1, #.DL.LCDDATA SHR 4
                                              AND
                                                   0FH
      MOV
               ARO, #.DL.LCDDATA
                                              AND OFH
      ADD
               ARO, PMNO
      ADDC
               AR1,
                        #0
                        #0
      ADDC
               AR2,
               AR3,
                        #0
      ADDC
      MOVT
               DBF,
                        @AR
               RPH, #0000B
      MOV
      MOV
               RPL, #0000B
      SKGE
               PMN0,
                        #0AH
      SET1
               СН
               LCDD1, DBF1
      LD
      LD
               LCDD0, DBF0
```

SET1

LCDEN



Figure 21-10. Example of Wiring of LCD Panel

# Correspondence between segment and common pins on LCD panel

| Segment          | Pin | L<br>C<br>D      | L<br>C<br>D | L<br>C<br>D | L<br>C<br>D | L<br>C<br>D | L<br>C<br>D | L<br>C<br>D | L<br>C<br>D | L<br>C<br>D | L<br>C<br>D | L<br>C<br>D | L<br>C<br>D | ь<br>С<br>С<br>С | ° do⊓ | L<br>C<br>D | L<br>C<br>D<br>6 | L<br>C<br>D<br>5 | L<br>C<br>D | L C D 3 | L<br>C<br>D | L<br>C<br>D | L<br>C<br>D<br>° |
|------------------|-----|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|------------------|-------|-------------|------------------|------------------|-------------|---------|-------------|-------------|------------------|
| Common Pin       |     | 45          | 46          | 47          | 48          | 49          | 50          | 51          | 52          | 53               | 54          | 55          | 56          | 57          | 58          | 59          | 60          | 61          | 62          | 63          | 64          | 65               | 66    | 67          | 68               | 69               | 70          | 71      | 72          | 73          | 74               |
| COM <sub>1</sub> | 43  | FM          | MW          |             |             | 1f          | 1e          | 1d          | 1a          | $\triangleright$ | А           | 2f          | 2e          | 2d          | 2a          | 3f          | 3e          | 3d          | За          | 4f          | 4e          | 4d               | 4a    | F           | E                | РМ               | AM          | 5f      | 5e          | 5d          | 5a               |
| COMo             | 44  | sw          | LW          |             |             | 1b          | 1g          | 1c          |             | ◁                | В           | 2b          | 2g          | 2c          | :           | 3b          | 3g          | 3с          | С           | 4b          | 4g          | 4c               | D     | 5           | G                | kHz              | MHz         | 5b      | 5g          | 5c          | СН               |



#### 21.6 Status on Reset

## 21.6.1 On power-ON reset

The LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins are specified as LCD segment signal output pins, and output a low level.

The COM<sub>1</sub> and COM<sub>0</sub> pins output a low level.

Therefore, the LCD display is turned OFF.

# 21.6.2 On execution of clock stop instruction

The LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins are specified as LCD segment signal output pins, and output a low level

The COM<sub>1</sub> and COM<sub>0</sub> pins output a low level.

Therefore, the LCD display is turned OFF.

#### 21.6.3 On CE reset

Of the LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins, those that are specified as segment signal output pins output segment signals, and those that are specified as general-purpose output port pins retain the current output value.

The COM<sub>1</sub> and COM<sub>0</sub> pins output common signals.

#### 21.6.4 In halt status

Of the LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins, those that are specified as segment signal output pins output segment signals, and those that are specified as general-purpose output port pins retain the current output value.

The COM<sub>1</sub> and COM<sub>0</sub> pins output common signals.

## 22. KEY SOURCE CONTROLLER/DECODER

The key source controller/decoder can configure a key matrix of up to 64 keys by outputting key source signals from the pins that also output LCD segment signals. Whether key source signals or LCD segment signals are output from the pins is controlled by means of time-division multiplexing.

# 22.1 Configuration of Key Source Controller/Decoder

Figure 22-1 shows the configuration of the key source controller/decoder.

As shown in the figure, the key source controller/decoder consists of a segment signal/key source signal timing control block, key source data register, key input control block, and P0D port register.

The following section 22.2 outlines the function of each block.

Control register Data buffer Key source data register (KSR) P0D port register 16 (data memory) LCD display data Key source data latch Segment signal/key source signal output timing control Key input control Ρ L C D 15 / K S 15 L C D 2 / K S 2 LCD1/KS POD3/ADC O D 1 / C D 14 / K S 14 O D 2 / 0 CD°/ Ď K S o A D C A D C A D C Key matrix

Figure 22-1. Block Diagram of Key Source Controller/Decoder



# 22.2 Functional Outline of Key Source Controller/Decoder

The key source controller/decoder can configure a key matrix of up to 64 keys by using key source signal output pins (LCD<sub>15</sub>/KS<sub>15</sub> through LCD<sub>0</sub>/KS<sub>0</sub>) and key input pins (P0D<sub>3</sub>/ADC<sub>5</sub> through P0D<sub>0</sub>/ADC<sub>2</sub>).

Figure 22-2 shows the example of key matrix configuration.

The LCD<sub>15</sub>/KS<sub>15</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins are multiplexed with LCD segment signal output pins.

Therefore, the key source signals and LCD segment signals are output by means of time-division multiplexing.

The following subsections 21.2.1 through 22.2.3 outline the function of each block of the key source controller/decoder.

Figure 22-2. Example of Key Matrix Configuration



#### 22.2.1 Key source data register (KSR)

The key source data register sets the key source output data of the pin that outputs a key source signal. Data are set to the key source data register via the data buffer.

When data are set to this register, the key source data are output from the LCD<sub>15</sub>/KS<sub>15</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins.

For details, refer to 22.3.

#### 22.2.2 Segment signal/key source signal output timing control block

The segment signal/key source signal output timing block controls the output timing of the key source and segment signals of the LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins.

Whether a key source signal is used or not is specified by the LCD mode select register.

The key source signal is not output when LCD display is not used. In this case, the above pins output a low level.

Whether LCD display is not used or not is specified by the LCD mode select register.

For details, refer to 22.4.

#### 22.2.3 Key input control block and P0D port register

The key input control block detects the key input signals input to the P0D<sub>3</sub>/ADC<sub>5</sub> through P0D<sub>0</sub>/ADC<sub>2</sub> pins in synchronization with key source signal output timing.

To output the key source signals from the LCD<sub>15</sub>/KS<sub>15</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins, therefore, the P0D<sub>3</sub>/ADC<sub>5</sub> through P0D<sub>0</sub>/ADC<sub>2</sub> pins are used as key input pins.

The key input data are read by the P0D port register (address 73H of BANK0) on the data memory.

Because the P0D<sub>3</sub>/ADC<sub>5</sub> through P0D<sub>0</sub>/ADC<sub>2</sub> pins are multiplexed with the A/D converter pins, care must be exercised when using these pins as the A/D converter pins.

For details, refer to 22.5.

# 22.3 Key Source Data Setting Block

## 22.3.1 Configuration of key source data setting block

Figure 22-3 shows the configuration of the key source data setting block.

Figure 22-3. Configuration of Key Source Data Setting Block



## 22.3.2 Function of key source data setting block

The key source data setting block sets the key source data to be output from the LCD<sub>15</sub>/KS<sub>15</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins.

The key source data are set to the key source data register (KSR: peripheral address 42H) via the data buffer. Each bit of the key source data register corresponds to the LCD<sub>15</sub>/KS<sub>15</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins, and sets the key source data of each pin.

When "1" is set to a bit of the key source data register, the pin corresponding to this bit outputs a high level as a key source signal; when the bit is reset to "0", the corresponding pin outputs a low level.

For the output timing, refer to 22.4.

The following subsections 22.3.3 explains the configuration and function of the key source data register. Also refer to **Figure 21-6** in **21. LCD CONTROLLER/DRIVER**.



# 22.3.3 Configuration and function of key source data register (KSR)

The configuration and function of the key source data register are illustrated below.



# 22.4 Output Timing Control Blocks and Segment/Port Select Block

# 22.4.1 Configuration of output timing control blocks and segment/port select block

Figure 22-4 shows the configuration of the common signal and segment signal/key source signal output timing control blocks and segment signal/general-purpose output port select block.

Figure 22-4. Configuration of Timing Control Blocks and Port Select Block





## 22.4.2 Function of output timing control blocks

The output timing control blocks controls the output timing of the key source and segment signals.

The LCD segment signal is output when the LCDEN flag of the LCD mode select register is "1".

All the LCD display dots can be turned OFF by resetting the LCDEN flag to "0". At this time, a low level is output as the segment signal, and the key source signal is not output.

To output the key source signal, therefore, the LCDEN flag must be "1".

The key source signal is also output when the KSEN flag of the LCD mode select register is "1".

Therefore, the KSEN flag is used to specify whether the key source signal is used or not.

To output the key source signal, therefore, the LCDEN and KSEN flags must be "1".

The following subsection 22.4.3 indicate the configuration and function of the LCD mode select register.

Subsection 22.4.4 shows the output waveforms of the key source and segment signals.

For the relation among the common and segment signals of the LCD, and key source signal, refer to **21. LCD CONTROLLER/DRIVER**.

## 22.4.3 Configuration and function of LCD mode select register

The LCD mode select register turns ON/OFF all the LCD display dots, and specifies output of the key source signal.

The configuration and function of this register are illustrated below.



## 22.4.4 Output waveforms of segment and key source signals

Figure 22-5 shows the output waveforms of the key source and segment signals.

As shown in the figure, the key source and segment signals are output by means of time-division multiplexing. The key source signal is output for 220  $\mu$ s at intervals of 4 ms.

To put it in another way, a pin corresponding to a bit of the key source data register that is set to "1" outputs a high level for 220  $\mu$ s every 4 ms, and a pin corresponding to a bit of the key source data register that is reset to "0" outputs a low level for 220  $\mu$ s every 4 ms.

When output of the key source signal is selected (KSEN flag = 1), pins that do not output key source signals ( $LCD_{29}/P0F_3$  through  $LCD_{16}$ ) output the waveform shown in Figure 22-5. However, a waveform of "0" is output as the key source data.



Figure 22-5. Output Waveforms of Key Source and Segment Signals



## **Connon signals**



# Each segment pin (pin outputting "1" as key source)



# Each segment pin (pin outputting "0" as key source)



# 22.5 Key Input Control Block

### 22.5.1 Configuration of key input control block

Figure 22-6 shows the configuration of the key input control block.

Control register Address b<sub>2</sub> b<sub>1</sub> Flag Κ 0 0 symbol Segment signal/key Write source signal output timing control instruction A/D converter Port register (1 bit) Input KEYJ P0D3/ADC5 C ad instruction Read & FF Reset Halt release Key source timing signal signal High ON resistance ADC channel select signal P0D<sub>2</sub>/ADC<sub>4</sub> O P0D<sub>1</sub>/ADC<sub>3</sub> O-P0D<sub>0</sub>/ADC<sub>2</sub> O-

Figure 22-6. Configuration of Key Input Control Block

# 22.5.2 Function of key input control block

The key input control block controls the timing to read the key input signals from the  $P0D_3/ADC_5$  through  $P0D_0/ADC_2$  pins and reads the key input data.

Figure 22-7 illustrates the key input signals and key input timing.

As shown in this figure, the internal-pull down resistors of the P0D<sub>3</sub>/ADC<sub>5</sub> through P0D<sub>0</sub>/ADC<sub>2</sub> pins are turned OFF while the display data of the LCD segment is output, and turned ON only for 220  $\mu$ s while the key source signal is output.

For the duration of 220  $\mu$ s during which the key source signal is output, the input signal of each key input pin is connected to the input latch.

Therefore, the signal input to each key input pin can be detected in the 220  $\mu$ s during which the key source signal is output.

Figure 22-8 shows the timing chart of the key source signal, key input signal, and key input data (P0D port register).

Whether a key source signal is output or not is detected by the KEYJ flag of the key input judge register (RF address 16H).

The KEYJ flag is set after the key source signal has been output for 220  $\mu$ s, and is reset when data has been set to the key source data register and when the content of the KEYJ flag has been read.

By detecting the KEYJ flag after the key source signal data has been output to the key source data register, and then detecting the status of each key input pin after the KEYJ flag has been set to "1", the key can be input.

The following subsection 22.5.3 explains the configuration and function of the key input judge register.



Figure 22-7. Key Source Signal and Key Input Timing



# Each segment pin (pin outputting "1" as key source, A = ON, B = OFF)



Figure 22-8. Timing Chart of Key Source Signal, Key Input Signal, and Key Input Data (P0D port register)



## 22.5.3 Configuration and function of key input judge register

The key input judge register detects the presence or absence of the key input signal latch when the LCD segment signal output pins are shared with key source signal output.

The configuration and functions of this register are illustrated below.



The key source data is set by setting the contents of the data buffer to the key source data register by using the "PUT" instruction.

When the key source signal output data is set by the "PUT" instruction via the data buffer, the KEYJ flag is reset to "0".

The KEYJ flag is also reset to "0" (Read & Reset) when the contents of the window register are read by the "PEEK" instruction.



# 22.6 Using Key Source Controller/Decoder

# 22.6.1 Configuring key matrix

Figure 22-9 shows an example of configuring a key matrix.

As shown in this figure, the key matrix can be configured for up to 64 keys.

Because the key source signal output pins also output the LCD segment signals at the same time, diode "A" must be used to prevent reverse flow of the LCD segment signal if a momentary switch is used.

Diodes "B" and "C" are used to prevent sneaking of the key source signal.

Use a PNP transistor as the transistor switch.

The following (1) explains the points to be noted when an NPN transistor is used.

(2) through (4) explain the points to be noted if diodes A, B, and C are not used.



Figure 22-9. Example of Key Matrix Configuration

## Configuration of each switch



#### (1) Notes on using NPN transistor switch

When an NPN transistor switch is used, the low level may not be accurately read as illustrated in the figure below.



If KS is low and a high level is input to the base of the transistor in the figure on the left, voltage  $V_K$  input to K is as follows.

$$V_{K} = \frac{R_{B}}{R_{A} + R_{B}} \times (V_{DD} - V_{BE})$$

A low level must be input to K at this time because KS is low. However, the voltage input to K changes depending on  $R_A$  and  $R_B$ , as indicated by the above expression.

Therefore, a low level may not be input depending on the values of  $R_{\text{A}}$  and  $R_{\text{B}}$ .

#### (2) Notes when diode A is not used

An example of a circuit where diode A is missing is shown below.

Suppose switches SW1 and SW2 are ON, KS<sub>15</sub> outputs a high level, and KS<sub>14</sub> outputs a low level, as shown below.

If diode A is missing, currents I<sub>1</sub> and I<sub>2</sub> indicated by the dotted lines flow.

Consequently, the high level of KS<sub>15</sub> and low level of KS<sub>14</sub> are not output correctly because of I<sub>2</sub>, and the key input data of K<sub>3</sub> cannot be accurately read.

If KS<sub>15</sub> and KS<sub>14</sub> are used to output LCD segment signals, the LCD cannot be turned ON/OFF correctly.





#### (3) Notes when diode B is not used

An example of a circuit where diode B is not used is shown below.

Suppose switches SW1, SW2, and SW4 are ON, and KS7 outputs a high level, as shown below.

If diode B is missing, currents I<sub>1</sub> and I<sub>2</sub> flow as indicated by the dotted lines.

Consequently, a high level is input to K<sub>2</sub> because of I<sub>2</sub> despite that switch SW3 is OFF, and it is judged that SW3 is ON.



#### (4) Note when diode C is not used

An example of a circuit where diode C is not used is shown below.

Suppose switches SW2, SW3, and SW4 are ON, and KS8 outputs a high level, as shown below.

If diode C is missing, currents I<sub>1</sub>, I<sub>2</sub>, and I<sub>3</sub> flow as indicated by the dotted lines.

Consequently, a high level is input to  $K_2$  because of  $I_2$  despite the fact that switch SW1 is OFF, and it is judged that SW1 is ON.

Moreover, KS<sub>8</sub> cannot output a high level correctly because of I<sub>3</sub>.





#### 22.6.2 Reading alternate switches and diode switches

Here is a program example.

# Example To read statuses of alternate and diode switches of LCD<sub>15</sub>/KS<sub>15</sub> through LCD<sub>8</sub>/KS<sub>8</sub> pins to addresses 20H through 27H of BANK0 of data memory

```
KS8
          NIBBLE8 0.20H
KEY_IN
                    0.73H
                                       ; P0D port register
          MEM
KEY_LOAD:
                                       ; LCD segment and key source signal output
           SET2
                    LCDEN, KSEN
                    DBF3, #0000B
                                       ; Sets key source data
          MOV
                                       ; Outputs low level from KS8
          MOV
                    DBF2, #0001B
                    DBF1, #0000B
          MOV
                    DBF0, #0000B
           MOV
          MOV
                    IXM, #0000B
          MOV
                    IXL, #0000B
          MOV
                    RPH, #0000B
           MOV
                    RPL, #0000B
KSCAN:
                    KSR, DBF
           PUT
                                       ; Outputs signal of key source data
LOOP:
           SKF1
                                       ; Determines if key input is latched
                    KEYJ
           BR
                    KCHECK
             Processing A
                                       ; Waits until key input is latched
           BR
                    LOOP
KCHECK:
          MOV
                    RPL#.DM.KEY_IN SHR 3 AND 0EH
           SET1
                    IXE
           ST
                    KS8, KEY_IN
                                       ; Stores key input data to data memory
           CLR1
                    IXE
           MOV
                    RPL, #0000B
           INC
                    ΙX
                    DBF2, DBF2
                                       ; Updates value of key source data and
           ADD
                    DBF3, DBF3
                                       ; scans key again
           ADD
                                       ; Determines if all key source lines are input
           SKT1
                    CY
           BR
                    KSCAN
 KEY_END:
                                       ; End of input
```



#### 22.6.3 Inputting momentary switch by binary search

The key source controller/decoder requires 4 ms to input the key of one key source signal line.

To input the keys of 16 key source signals, therefore, it takes 64 ms.

It is therefore convenient if the binary search method explained in (1) and (2) below is used.

#### (1) Flowchart

#### When KS7 through KS0 are used as key source signals of momentary switch



#### Example of table data for binary search

| Shift<br>Address |             | Table Data<br>(Key Source Data) |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
|------------------|-------------|---------------------------------|-------------|-----------------|-----------------|-------------|----------------|----------------|----------------|----------------|------------|----------------|----|----------------|----------------|----|
| (RA)             | <b>b</b> 15 | b <sub>14</sub>                 | <b>b</b> 13 | b <sub>12</sub> | b <sub>11</sub> | <b>b</b> 10 | b <sub>9</sub> | b <sub>8</sub> | b <sub>7</sub> | b <sub>6</sub> | <b>b</b> 5 | b <sub>4</sub> | bз | b <sub>2</sub> | b <sub>1</sub> | bo |
| 0000B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 0001B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 0010B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 0011B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 0100B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 0101B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 0110B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 0111B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 1000B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 1001B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 1010B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 1011B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 1100B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 1101B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 1110B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |
| 1111B            |             |                                 |             |                 |                 |             |                |                |                |                |            |                |    |                |                |    |

## (2) Program example

```
RA
       MEM
              0.1AH
                                      ; General-purpose work register
                                      ; General-purpose work register
RB
              0.1BH
       MEM
                                      ; General-purpose work register
       MEM
              0.1CH
                                      ; P0D port register
KEY_IN MEM
              0.73H
KSDATA:
              KKKKKKKKKKKKKKK
              SSSSSSSSSSSSS
              1111119876543210
              543210
        ;
       DW
              000000011111111B
                                      ; RA = 0
              000000011110000B
                                      ; RA = 1
       DW
              000000000001100B
                                      ; RA = 2
              000000000110000B
                                      ; RA = 3
       DW
                                      ; RA = 4
              0000000000000010B
                                      ; RA = 5
              000000000001000B
       DW
                                      ; RA = 6
              000000000100000B
              000000010000000B
                                      ; RA = 7
       DW
       DW
              0000000000000001B
                                      ; RA = 8
                                      ; RA = 9
              0000000000000010B
       DW
              0000000000000100B
                                      ; RA = 10
       DW
                                      ; RA = 11
       DW
              000000000001000B
       DW
              000000000010000B
                                      ; RA = 12
                                      ; RA = 13
              000000000100000B
       DW
              000000001000000B
                                      ; RA = 14
       DW
              000000010000000B
                                      ; RA = 15
KEY_LOAD:
                                      ; LCD segment and key source signal output
              LCDEN, KSEN
       SET2
START:
       MOV
              RA, #0000B
```



```
KSCAN:
        MOV
               AR3, #.DL.KSDATA SHR OCH AND OFH
        MOV
               AR2, #.DL.KSDATA SHR 8 AND 0FH
        MOV
               AR1, #.DL.KSDATA SHR 4 AND 0FH
               ARO, #.DL.KSDATA AND OFH
        VOM
        MOV
               RPL, #.DL.ARO SHR 3 AND 0EH
        ADD
               ARO, RA
        ADDC
              AR1, #0
        ADDC
               AR2, #0
        ADDC
               AR3, #0
        MOV
               RPL, #0
               DBF, @AR
                                       ; Reads table data
        TVOM
                                       ; Outputs signal of key source data
        PUT
               KSR, DBF
LOOP1:
                                       ; Determines if key input is latched
               KEYJ
        SKF1
        BR
               KCHECK
                                       ; Waits until key input is latched
           Processing A
        BR
               LOOP1
KCHECK:
        MOV
               PRL, #.DM.RB SHR 3 AND 0EH
               RB, KEY_IN
                                       ; Stores key input data to RB
        LD
                                       ; All keys are checked?
        SKNE RA, #0000B
               RB, #0000B
        SKE
        BR
               Key input
        BR
               START
                                       ; There is no key input
Key input:
                                       ; Key sources are narrowed down to one?
        SKLT
               RA, RA
               LASTCHK
                                       ; If not, updates value of RA, and scans keys again
        ADD
               RA, RA
               RB, #0000B
        SKE
        ADD
               RA, #0001B
        BR
               KSCAN
LASTCHK:
               RPL, #0
        MOV
                                       ; Key input to one key source?
        SKNE RB, #0000B
                                       ; If not, it is determined that chattering occurs
        BR
               START
```

Chattering wait

LOOP2:

SKF1 KEYJ ; Determines if key input is latched

BR KEYDEC

Processing B ; Waits until key input is latched

BR LOOP2

KEYDEC:

MOV RPL, #.DM.RC SHR 3 AND 0EH

 ${\tt LD} \qquad {\tt RC}\,, \ {\tt KEY\_IN} \qquad \qquad ; \mbox{Stores key input data to latch}$ 

SET2 CAP, Z ; Compares key input data after chattering with key input

SUB RC, RB; data before chattering wait

SKT1 Z

BR START ; If data differ

KEY\_END:

; Stores key source data to RA, key input data before

; chattering to RB, and key input data after chattering to RC



#### 22.7 Status on Reset

#### 22.7.1 On power-ON reset

The LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins are specified as the LCD segment signal output pins and output a low level (display OFF). A low level is output as the key source signal.

#### 22.7.2 On execution of clock stop instruction

The LCD<sub>29</sub>/P0F<sub>3</sub> through LCD<sub>0</sub>/KS<sub>0</sub> pins are specified as the LCD segment signal output pins and output a low level (display OFF). A low level is output as the key source signal.

#### 22.7.3 On CE reset

The output data is retained as is if the key source signal is being output.

#### 22.7.4 In halt status

The output data is retained as is if the key source signal is being output.

If key input is specified as a halt status releasing condition, the halt status is released when a high level is input to the P0D<sub>3</sub>/ADC<sub>5</sub> through P0D<sub>0</sub>/ADC<sub>2</sub> pins.

If the key source controller is used, however, the halt status is released only by a high level that is input within 220  $\mu$ s during which the key source data is output.

To release the halt status by key input by using the key source controller, do not use the  $P0D_3/ADC_5$  through  $P0D_0/ADC_2$  pins for the A/D converter.

For an explanation of how to release the halt status by key input, refer to 12.4 Halt Function.



## 23. INSTRUCTION SET

## 23.1 Outline of Instruction Set

| b <sub>14</sub> -b <sub>11</sub> |     |                                                                                         | 0                                                          |      | 1             |
|----------------------------------|-----|-----------------------------------------------------------------------------------------|------------------------------------------------------------|------|---------------|
| BIN                              | HEX |                                                                                         |                                                            |      |               |
| 0000                             | 0   | ADD                                                                                     | r, m                                                       | ADD  | m, #n4        |
| 0001                             | 1   | SUB                                                                                     | r, m                                                       | SUB  | m, #n4        |
| 0010                             | 2   | ADDC                                                                                    | r, m                                                       | ADDC | m, #n4        |
| 0011                             | 3   | SUBC                                                                                    | r, m                                                       | SUBC | m, #n4        |
| 0100                             | 4   | AND                                                                                     | r, m                                                       | AND  | m, #n4        |
| 0101                             | 5   | XOR                                                                                     | r, m                                                       | XOR  | m, #n4        |
| 0110                             | 6   | OR                                                                                      | r, m                                                       | OR   | m, #n4        |
| 0111                             | 7   | INC INC RORC MOVT PUSH POP GET PUT PEEK POKE BR CALL RET RETSK RETI EI DI STOP HALT NOP | AR IX r DBF, @AR AR AR DBF, p p, DBF WR, rf rf, WR @AR @AR |      |               |
| 1000                             | 8   | LD                                                                                      | r, m                                                       | ST   | m, r          |
| 1001                             | 9   | SKE                                                                                     | m, #n4                                                     | SKGE | m, #n4        |
| 1010                             | Α   | MOV                                                                                     | @r, m                                                      | MOV  | m, @r         |
| 1011                             | В   | SKNE                                                                                    | m, #n4                                                     | SKLT | m, #n4        |
| 1100                             | С   | BR                                                                                      | addr (page 0)                                              | CALL | addr (page 0) |
| 1101                             | D   | BR                                                                                      | addr (page 1)                                              | MOV  | m, #n4        |
| 1110                             | Е   | BR                                                                                      | addr (page 2)                                              | SKT  | m, #n         |
| 1111                             | F   | BR                                                                                      | addr (page 3)                                              | SKF  | m, #n         |



#### 23.2 Legend

AR : address register

ASR : address stack register indicated by stack pointer addr : program memory address (low-order 11 bits)

BANK : bank register
CMP : compare flag
CY : carry flag
DBF : data buffer

h : halt release condition INTEF : interrupt enable flag

INTR : register automatically saved to stack when interrupt occurs

INTSK : interrupt stack register

IX : index register

MP : data memory row address pointer

MPE : memory pointer enable flag

m : data memory address indicated by mR, mc
 mR : data memory row address (high-order)
 mc : data memory column address (low-order)

n : bit position (4 bits) n4 : immediate data (4 bits)

PAGE : page (bit 11 of program counter:  $\mu$ PD17016)

(bits 11 and 12 of program counter:  $\mu$ PD17017)

PC : program counter p : peripheral address

рн : peripheral address (high-order 3 bits)
рь : peripheral address (low-order 4 bits)
г : general register column address

rf : register file address

rfR : register file address (high-order 3 bits)
nfc : register file address (low-order 4 bits)

SP : stack pointer

s : stop release condition

WR : window register

( $\times$ ) : contents addressed by  $\times$ 



## 23.3 Instruction Set List

| Instructions | Mnemonic                                                    | Operand  | Operation                                                                                                                                | Ins     | Instruction Code |            |      |  |  |
|--------------|-------------------------------------------------------------|----------|------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------|------------|------|--|--|
|              |                                                             |          |                                                                                                                                          | op Code | (                | Operand    | d    |  |  |
| Add ADD      |                                                             | r, m     | $(r) \leftarrow (r) + (m)$                                                                                                               | 00000   | <b>m</b> R       | mc         | r    |  |  |
|              |                                                             | m, #n4   | (m) ← (m) + n4                                                                                                                           | 10000   | mR               | mc         | n4   |  |  |
|              | ADDC                                                        | r, m     | $(r) \leftarrow (r) + (m) + CY$                                                                                                          | 00010   | <b>m</b> R       | mc         | r    |  |  |
|              |                                                             | m, #n4   | (m) ← (m) + n4 + CY                                                                                                                      | 10010   | mR               | mc         | n4   |  |  |
|              | INC                                                         | AR       | AR ← AR + 1                                                                                                                              | 00111   | 000              | 1001       | 0000 |  |  |
|              |                                                             | IX       | IX ← IX + 1                                                                                                                              | 00111   | 000              | 1000       | 0000 |  |  |
| Subtract     | SUB                                                         | r, m     | $(r) \leftarrow (r) - (m)$                                                                                                               | 00001   | mR               | <b>m</b> c | r    |  |  |
|              |                                                             | m, #n4   | (m) ← (m) − n4                                                                                                                           | 10001   | mR               | mc         | n4   |  |  |
|              | SUBC                                                        | r, m     | $(r) \leftarrow (r) - (m) - CY$                                                                                                          | 00011   | <b>m</b> R       | <b>m</b> c | r    |  |  |
|              |                                                             | m, #n4   | $(m) \leftarrow (m) - n4 - CY$                                                                                                           | 10011   | mR               | <b>m</b> c | n4   |  |  |
| Logical      | OR                                                          | r, m     | $(r) \leftarrow (r) \lor (m)$                                                                                                            | 00110   | mR               | mc         | r    |  |  |
| operation    |                                                             | m, #n4   | $(m) \leftarrow (m) \lor n4$                                                                                                             | 10110   | <b>m</b> R       | <b>m</b> c | n4   |  |  |
|              | AND                                                         | r, m     | $(r) \leftarrow (r) \land (m)$                                                                                                           | 00100   | mR               | mc         | r    |  |  |
|              |                                                             | m, #n4   | (m) ← (m) ∧ n4                                                                                                                           | 10100   | <b>m</b> R       | mc         | n4   |  |  |
|              | XOR                                                         | r, m     | $(r) \leftarrow (r) \ \forall \ (m)$                                                                                                     | 00101   | mR               | mc         | r    |  |  |
|              |                                                             | m, #n4   | (m) ← (m) ∀ n4                                                                                                                           | 10101   | mR               | mc         | n4   |  |  |
| Judge        | Judge         SKT         m, #n           SKF         m, #n |          | $CMP \leftarrow 0$ , if (m) $\wedge$ n = n, then skip                                                                                    | 11110   | <b>m</b> R       | mc         | n    |  |  |
|              |                                                             |          | $CMP \leftarrow 0$ , if (m) $\wedge$ n = 0, then skip                                                                                    | 11111   | <b>m</b> R       | mc         | n    |  |  |
| Compare      | SKE                                                         | m, #n4   | n, #n4 (m) - n4, skip if zero                                                                                                            |         | mR               | mc         | n4   |  |  |
|              | SKNE                                                        | m, #n4   | (m) - n4, skip if not zero                                                                                                               | 01011   | mR               | mc         | n4   |  |  |
|              | SKGE                                                        | m, #n4   | (m) - n4, skip if not borrow                                                                                                             | 11001   | <b>m</b> R       | <b>m</b> c | n4   |  |  |
|              | SKLT                                                        | m, #n4   | (m) – n4, skip if borrow                                                                                                                 | 11011   | mR               | mc         | n4   |  |  |
| Rotate       | RORC                                                        | r        | $	riangle$ CY $	o$ (r) $	ext{b3}$ $	o$ (r) $	ext{b2}$ $	o$ (r) $	ext{b1}$ $	o$ (r) $	ext{b0}$                                            | 00111   | 000              | 0111       | r    |  |  |
| Transfer     | LD                                                          | r, m     | $(r) \leftarrow (m)$                                                                                                                     | 01000   | mR               | mc         | r    |  |  |
|              | ST                                                          | m, r     | (m) ← (r)                                                                                                                                | 11000   | mR               | mc         | r    |  |  |
|              | MOV                                                         | @r, m    | if MPE = 1: $(MP, (r)) \leftarrow (m)$<br>if MPE = 0: $(BANK, m_R, (r)) \leftarrow (m)$                                                  | 01010   | MR               | <b>m</b> c | r    |  |  |
|              |                                                             | m, @r    | if MPE = 1: $(m) \leftarrow (MP, (r))$<br>if MPE = 0: $(m) \leftarrow (BANK, m_R, (r))$                                                  | 11010   | MR               | mc         | r    |  |  |
|              |                                                             | m, #n4   | (m) ← n4                                                                                                                                 | 11101   | mR               | mc         | n4   |  |  |
|              | MOVT                                                        | DBF, @AR | $SP \leftarrow SP - 1$ , $ASR \leftarrow PC$ , $PC \leftarrow AR$ , $DBF \leftarrow (PC)$ , $PC \leftarrow ASR$ , $SP \leftarrow SP + 1$ | 00111   | 000              | 0001       | 0000 |  |  |
|              | PUSH                                                        | AR       | $SP \leftarrow SP - 1$ , $ASR \leftarrow AR$                                                                                             | 00111   | 000              | 1101       | 0000 |  |  |
|              | POP                                                         | AR       | $AR \leftarrow ASR, SP \leftarrow SP + 1$                                                                                                | 00111   | 000              | 1100       | 0000 |  |  |
|              | PEEK                                                        | WR, rf   | $WR \leftarrow (rf)$                                                                                                                     | 00111   | rfR              | 0011       | rfc  |  |  |

Caution The program memory addresses that can be specified by the address register range as follows:

 $\mu \mbox{PD17016}\colon$  0000H through 00FFH  $\mu \mbox{PD17017}\colon$  0000H through 1EFBH



| Instructions Mnemonic |       | Operand | Operand Operation                                                                                    |         | structio | n Code  |      |
|-----------------------|-------|---------|------------------------------------------------------------------------------------------------------|---------|----------|---------|------|
|                       |       |         |                                                                                                      | op Code | (        | Operand | t    |
| Transfer              | POKE  | rf, WR  | $(rf) \leftarrow WR$                                                                                 | 00111   | rfR      | 0010    | rfc  |
|                       | GET   | DBF, p  | DBF ← (p)                                                                                            | 00111   | рн       | 1011    | рь   |
|                       | PUT   | p, DBF  | (p) ← DBF                                                                                            | 00111   | рн       | 1010    | рь   |
| Branch                | BR    | addr    | Note                                                                                                 | Note    |          | addr    |      |
|                       |       | @AR     | PC ← AR                                                                                              | 00111   | 000      | 0100    | 0000 |
|                       |       | addr    | $SP \leftarrow SP - 1$ , $ASR \leftarrow PC$<br>$PC_{11} \leftarrow 0$ , $PC_{10-0} \leftarrow addr$ | 11100   |          | addr    |      |
|                       |       | @AR     | $SP \leftarrow SP - 1$ , $ASR \leftarrow PC$<br>$PC \leftarrow AR$                                   | 00111   | 000      | 0101    | 000  |
|                       | RET   |         | $PC \leftarrow ASR, SP \leftarrow SP + 1$                                                            | 00111   | 000      | 1110    | 0000 |
|                       | RETSK |         | $PC \leftarrow ASR, SP \leftarrow SP + 1$ and skip                                                   | 00111   | 001      | 1110    | 0000 |
|                       | RETI  |         | $PC \leftarrow ASR, INTR \leftarrow INTSK, SP \leftarrow SP + 1$                                     | 00111   | 010      | 1110    | 0000 |
| Interrupt             | EI    |         | INTEF ← 1                                                                                            | 00111   | 000      | 1111    | 0000 |
|                       | DI    |         | INTEF ← 0                                                                                            | 00111   | 001      | 1111    | 0000 |
| Others                | STOP  | S       | STOP                                                                                                 | 00111   | 010      | 1111    | S    |
|                       | HALT  | h       | HALT                                                                                                 | 00111   | 011      | 1111    | h    |
|                       | NOP   |         | No operation                                                                                         | 00111   | 100      | 1111    | 0000 |

**Note** The operation and op code of "BR addr" of the  $\mu$ PD17016 and  $\mu$ PD17017 are as follows.

## (a) $\mu$ PD17016

| Mnemonic | Operand | Operation                                      | op Code |
|----------|---------|------------------------------------------------|---------|
| BR       | addr    | $PC_{10-0} \leftarrow addr, PAGE \leftarrow 0$ | 01100   |
|          |         | PC <sub>10-0</sub> ← addr, PAGE ← 1            | 01101   |

## **(b)** $\mu$ **PD17017**

| Mnemonic | Operand | Operation                                      | op Code |
|----------|---------|------------------------------------------------|---------|
| BR       | addr    | $PC_{10-0} \leftarrow addr, PAGE \leftarrow 0$ | 01100   |
|          |         | PC <sub>10-0</sub> ← addr, PAGE ← 1            | 01101   |
|          |         | $PC_{10-0} \leftarrow addr, PAGE \leftarrow 2$ | 01110   |
|          |         | $PC_{10-0} \leftarrow addr, PAGE \leftarrow 3$ | 01111   |

Caution The program memory addresses that can be specified by the address register range as follows:

 $\mu$ PD17016: 0000H through 00FFH  $\mu$ PD17017: 0000H through 1EFBH



## 23.4 Assembler (AS17K) Embedded Macroinstruction

## Legend

flag n: FLG symbol n : bit number <> : can be omitted

|          | Mnemonic            | Operand                                             | Operation                                                                                                       | n         |  |  |
|----------|---------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-----------|--|--|
| Embedded | SKTn                | flag 1, flag n                                      | if (flag 1) to (flag n) = all "1", then skip                                                                    | 1 ≤ n ≤ 4 |  |  |
| macro    | SKFn                | flag 1, flag n                                      | if (flag 1) to (flag n) = all "0", then skip                                                                    | 1 ≤ n ≤ 4 |  |  |
|          | SETn                | flag 1, flag n                                      | (flag 1) to (flag n) $\leftarrow$ 1                                                                             | 1 ≤ n ≤ 4 |  |  |
|          | CLRn flag 1, flag n |                                                     | lag 1, flag n (flag 1) to (flag n) $\leftarrow$ 0                                                               |           |  |  |
|          | NOTn                | flag 1, flag n                                      | if (flag n) = "0", then (flag n) $\leftarrow$ 1 if (flag n) = "1", then (flag n) $\leftarrow$ 0                 | 1 ≤ n ≤ 4 |  |  |
|          | INITFLG             | <not> flag 1,<br/> &lt;<not> flag n&gt;</not></not> | if description = NOT flag n, then (flag n) $\leftarrow$ 0 if description = flag n, then (flag n) $\leftarrow$ 1 | 1 ≤ n ≤ 4 |  |  |
|          | BANKn               |                                                     | (BANK) ← n                                                                                                      | Note      |  |  |

**Note**  $0 \le n \le 2$ :  $\mu PD17016$   $0 \le n \le 3$ :  $\mu PD17017$ 



#### 23.5 Software Macroinstructions

#### 23.5.1 BEEP output software macro

| Item                 | Macro format | Function          |  |  |
|----------------------|--------------|-------------------|--|--|
| Controls BEEP output | BEEPON200    | Outputs 200 Hz    |  |  |
|                      | BEEPON1K     | Outputs 1 kHz     |  |  |
|                      | BEEPON3K     | Outputs 3 kHz     |  |  |
|                      | BEEPOFF      | Stops BEEP output |  |  |

Caution If the above macros are used, the contents of the window register are destroyed.

If an embedded macro instruction is used immediately before the above macro instructions, an "object error" occurs when the source file is assembled and then loaded to the in-circuit emulator. To use an embedded macro instruction immediately before the above macro instructions, insert a comment statement between them.

#### 23.5.2 Flag manipulation software macro

| Item                                | Macro format      | Function                                                             |
|-------------------------------------|-------------------|----------------------------------------------------------------------|
| Detects INT <sub>0</sub> pin status | SKT1_INT0         | Skips next instruction if high level is input to INTo pin            |
|                                     | SKF1_INT0         | Skips next instruction if low level is input to INT <sub>0</sub> pin |
| Sets interrupt enable flag          | SET1_IPTM         | Enables timer interrupt                                              |
|                                     | SET1_IP0          | Enables INT₀ pin interrupt                                           |
|                                     | SET2_IPTM_IP0     | Enables timer interrupt and INT₀ pin interrupt                       |
|                                     | CLR1_IPTM         | Disables timer interrupt                                             |
|                                     | CLR1_IP0          | Disables INT₀ pin interrupt                                          |
|                                     | CLR2_IPTM_IP0     | Disables timer interrupt and INTo pin interrupt                      |
|                                     | INIT_NOT_IPTM_IP0 | Disables timer interrupt and enables INT <sub>0</sub> pin interrupt  |
|                                     | INIT_IPTM_NOT_IP0 | Enables timer interrupt and disables INT <sub>0</sub> pin interrupt  |
| Resets interrupt request flag       | CLR1_IRQTMNote    | Resets timer interrupt request                                       |
|                                     | CLR1_IRQ0Note     | Resets INT₀ pin interrupt request                                    |

**Note** While any of these macros is executed, any other interrupt request cannot be acknowledged. For details, refer to **10.11 Notes on Using Interrupt**.

Caution If the above macros are used, the contents of the window register are destroyed.

If an embedded macro instruction is used immediately before the above macro instructions, an "object error" occurs when the source file is assembled and then loaded to the in-circuit emulator. To use an embedded macro instruction immediately before the above macro instructions, insert a comment statement between them.



| Item                                         | Macro format           | Function                                                                                                                                                                                                                              |  |  |  |
|----------------------------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Sets general-purpose output port/LCD segment | SET1_P0EON             | Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as general-purpose output port                                                                                                                     |  |  |  |
| signal output (P0E, P0F)                     | SET1_P0FON             | Uses LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as general-purpose output port                                                                                                                     |  |  |  |
|                                              | SET2_P0EON_P0FON       | Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as general-purpose output port                                   |  |  |  |
|                                              | CLR1_P0EON             | Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as LCD segment signal output pins                                                                                                                  |  |  |  |
|                                              | CLR1_P0FON             | Uses LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as LCD segment signal output pins                                                                                                                  |  |  |  |
|                                              | CLR2_P0EON_P0FON       | Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as LCD segment signal output pins                                     |  |  |  |
|                                              | INIT_NOT_P0EON_P0FON   | Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as LCD segment signal output pins and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as general-purpose output port |  |  |  |
|                                              | INIT_P0EON_NOT_P0FON   | Uses LCD <sub>22</sub> /P0E <sub>0</sub> -LCD <sub>25</sub> /P0E <sub>3</sub> pins as general-purpose output port and LCD <sub>26</sub> /P0F <sub>0</sub> -LCD <sub>29</sub> /P0F <sub>3</sub> pins as LCD segment signal output pins |  |  |  |
| Sets general-purpose                         | SET1_PWM0ON            | Uses P1B₁/PWM₀ pin as PWM pin                                                                                                                                                                                                         |  |  |  |
| output port/PWM pin signal                   | SET1_PWM1ON            | Uses P1B <sub>2</sub> /PWM <sub>1</sub> pin as PWM pin                                                                                                                                                                                |  |  |  |
| (P1B <sub>1</sub> , P1B <sub>2</sub> )       | SET2_PWM1ON_PWM0ON     | Uses P1B <sub>1</sub> /PWM <sub>0</sub> and P1B <sub>2</sub> /PWM <sub>1</sub> pins as PWM pins                                                                                                                                       |  |  |  |
|                                              | CLR1_PWM0ON            | Uses P1B₁/PWM₀ pin as general-purpose output port pin                                                                                                                                                                                 |  |  |  |
|                                              | CLR1_PWM1ON            | Uses P1B <sub>2</sub> /PWM <sub>1</sub> pin as general-purpose output port pin                                                                                                                                                        |  |  |  |
|                                              | CLR2_PWM1ON_PWM0ON     | Uses P1B <sub>1</sub> /PWM <sub>0</sub> and P1B <sub>2</sub> /PWM <sub>1</sub> pins as general-purpose output port pins                                                                                                               |  |  |  |
|                                              | INIT_NOT_PWM1ON_PWM0ON | Uses P1B <sub>1</sub> /PWM <sub>0</sub> pin as PWM pin and P1B <sub>2</sub> /PWM <sub>1</sub> pin as general-purpose output port pin                                                                                                  |  |  |  |
|                                              | INIT_PWM1ON_NOT_PWM0ON | Uses P1B <sub>1</sub> /PWM <sub>0</sub> pin as general-purpose output port pin and P1B <sub>2</sub> /PWM <sub>1</sub> pin as PWM pin                                                                                                  |  |  |  |

# Caution If the above macros are used, the contents of the window register are destroyed. If an embedded macro instruction is used immediately before the above macro instructions, an "object error" occurs when the source file is assembled and then loaded to the in-circuit emulator. To use an embedded macro instruction immediately before the above macro instructions, insert a comment statement between them.



## 24. RESERVED SYMBOL

## 24.1 Data Buffer (DBF)

| Symbol Name | Attribute | Value | R/W | Description               |
|-------------|-----------|-------|-----|---------------------------|
| DBF3        | MEM       | 0.0CH | R/W | Bits 15 through 12 of DBF |
| DBF2        | MEM       | 0.0DH | R/W | Bits 11 through 8 of DBF  |
| DBF1        | MEM       | 0.0EH | R/W | Bits 7 through 4 of DBF   |
| DBF0        | MEM       | 0.0FH | R/W | Bits 3 through 0 of DBF   |

## 24.2 System Register (SYSREG)

| Symbol Name | Attribute | Value   | R/W | Description                                   |
|-------------|-----------|---------|-----|-----------------------------------------------|
| AR3         | MEM       | 0.74H   | R   | Bits 15 through 12 of address register Note 1 |
| AR2         | MEM       | 0.75H   | R   | Bits 11 through 8 of address register Note 2  |
| AR1         | MEM       | 0.76H   | R/W | Bits 7 through 4 of address register          |
| AR0         | MEM       | 0.77H   | R/W | Bits 3 through 0 of address register          |
| WR          | MEM       | 0.78H   | R/W | Window register                               |
| BANK        | MEM       | 0.79H   | R/W | Bank register                                 |
| IXH         | MEM       | 0.7AH   | R/W | Index register, high                          |
| MPH         | MEM       | 0.7AH   | R/W | Memory pointer, high                          |
| MPE         | FLG       | 0.7AH.3 | R/W | Memory pointer enable flag                    |
| IXM         | MEM       | 0.7BH   | R/W | Index register, middle                        |
| MPL         | MEM       | 0.7BH   | R/W | Memory pointer, low                           |
| IXL         | MEM       | 0.7CH   | R/W | Index register, low                           |
| RPH         | MEM       | 0.7DH   | R/W | General register pointer, high                |
| RPL         | MEM       | 0.7EH   | R/W | General register pointer, low                 |
| PSW         | MEM       | 0.7FH   | R/W | Program status word                           |
| BCD         | FLG       | 0.7EH.0 | R/W | BCD operation flag                            |
| CMP         | FLG       | 0.7FH.3 | R/W | Compare flag                                  |
| CY          | FLG       | 0.7FH.2 | R/W | Carry flag                                    |
| Z           | FLG       | 0.7FH.1 | R/W | Zero flag                                     |
| IXE         | FLG       | 0.7FH.0 | R/W | Index enable flag                             |

**Notes 1.** All the 4 bits are fixed to "0" with the  $\mu$ PD17016. The high-order 3 bits are fixed to "0" with the  $\mu$ PD17017.

2. The 4 bits are always fixed to "0" with the  $\mu$ PD17016.

\*



## 24.3 LCD Segment Register

| Symbol Name | Attribute | Value | R/W | Description          |
|-------------|-----------|-------|-----|----------------------|
| LCDD0       | MEM       | 0.60H | R/W | LCD segment register |
| LCDD1       | MEM       | 0.61H | R/W | LCD segment register |
| LCDD2       | MEM       | 0.62H | R/W | LCD segment register |
| LCDD3       | MEM       | 0.63H | R/W | LCD segment register |
| LCDD4       | MEM       | 0.64H | R/W | LCD segment register |
| LCDD5       | MEM       | 0.65H | R/W | LCD segment register |
| LCDD6       | MEM       | 0.66H | R/W | LCD segment register |
| LCDD7       | MEM       | 0.67H | R/W | LCD segment register |
| LCDD8       | MEM       | 0.68H | R/W | LCD segment register |
| LCDD9       | MEM       | 0.69H | R/W | LCD segment register |
| LCDD10      | MEM       | 0.6AH | R/W | LCD segment register |
| LCDD11      | MEM       | 0.6BH | R/W | LCD segment register |
| LCDD12      | MEM       | 0.6CH | R/W | LCD segment register |
| LCDD13      | MEM       | 0.6DH | R/W | LCD segment register |
| LCDD14      | MEM       | 0.6EH | R/W | LCD segment register |

## 24.4 Port Register

| Symbol Name | Attribute | Value   | R/W               | Description      |
|-------------|-----------|---------|-------------------|------------------|
| P0A3        | FLG       | 0.70H.3 | R/W               | Bit 3 of port 0A |
| P0A2        | FLG       | 0.70H.2 | R/W               | Bit 2 of port 0A |
| P0A1        | FLG       | 0.70H.1 | R/W               | Bit 1 of port 0A |
| P0A0        | FLG       | 0.70H.0 | R/W               | Bit 0 of port 0A |
| P0B3        | FLG       | 0.71H.3 | R/W               | Bit 3 of port 0B |
| P0B2        | FLG       | 0.71H.2 | R/W               | Bit 2 of port 0B |
| P0B1        | FLG       | 0.71H.1 | R/W               | Bit 1 of port 0B |
| P0B0        | FLG       | 0.71H.0 | R/W               | Bit 0 of port 0B |
| P0C3        | FLG       | 0.72H.3 | R/W               | Bit 3 of port 0C |
| P0C2        | FLG       | 0.72H.2 | R/W               | Bit 2 of port 0C |
| P0C1        | FLG       | 0.72H.1 | R/W               | Bit 1 of port 0C |
| P0C0        | FLG       | 0.72H.0 | R/W               | Bit 0 of port 0C |
| P0D3        | FLG       | 0.73H.3 | RNote             | Bit 3 of port 0D |
| P0D2        | FLG       | 0.73H.2 | RNote             | Bit 2 of port 0D |
| P0D1        | FLG       | 0.73H.1 | RNote             | Bit 1 of port 0D |
| P0D0        | FLG       | 0.73H.0 | R <sup>Note</sup> | Bit 0 of port 0D |

**Note** This port is an input port, but the assembler or in-circuit emulator does not output an error message even if an instruction that writes data to this port is described. Moreover, the operation is not affected even if such a program is actually executed on the device.



## 24.4 Port Register

| Symbol Name | Attribute | Value   | R/W   | Description      |
|-------------|-----------|---------|-------|------------------|
| P0E3        | FLG       | 0.6BH.3 | R/W   | Bit 3 of port 0E |
| P0E2        | FLG       | 0.6BH.2 | R/W   | Bit 2 of port 0E |
| P0E1        | FLG       | 0.6BH.1 | R/W   | Bit 1 of port 0E |
| P0E0        | FLG       | 0.6BH.0 | R/W   | Bit 0 of port 0E |
| P0F3        | FLG       | 0.6DH.3 | R/W   | Bit 3 of port 0F |
| P0F2        | FLG       | 0.6DH.2 | R/W   | Bit 2 of port 0F |
| P0F1        | FLG       | 0.6DH.1 | R/W   | Bit 1 of port 0F |
| P0F0        | FLG       | 0.6DH.0 | R/W   | Bit 0 of port 0F |
| P1A3        | FLG       | 1.70H.3 | R/W   | Bit 3 of port 1A |
| P1A2        | FLG       | 1.70H.2 | R/W   | Bit 2 of port 1A |
| P1A1        | FLG       | 1.70H.1 | R/W   | Bit 1 of port 1A |
| P1A0        | FLG       | 1.70H.0 | R/W   | Bit 0 of port 1A |
| P1B3        | FLG       | 1.71H.3 | R/W   | Bit 3 of port 1B |
| P1B2        | FLG       | 1.71H.2 | R/W   | Bit 2 of port 1B |
| P1B1        | FLG       | 1.71H.1 | R/W   | Bit 1 of port 1B |
| P1B0        | FLG       | 1.71H.0 | R/W   | Bit 0 of port 1B |
| P1C3        | FLG       | 1.72H.3 | R/W   | Bit 3 of port 1C |
| P1C2        | FLG       | 1.72H.2 | R/W   | Bit 2 of port 1C |
| P1C1        | FLG       | 1.72H.1 | R/W   | Bit 1 of port 1C |
| P1C0        | FLG       | 1.72H.0 | R/W   | Bit 0 of port 1C |
| P1D3        | FLG       | 1.73H.3 | RNote | Bit 3 of port 1D |
| P1D2        | FLG       | 1.73H.2 | RNote | Bit 2 of port 1D |
| P1D1        | FLG       | 1.73H.1 | RNote | Bit 1 of port 1D |
| P1D0        | FLG       | 1.73H.0 | RNote | Bit 0 of port 1D |
| P2A0        | FLG       | 2.70H.0 | R/W   | Bit 0 of port 2A |

**Note** This port is an input port, but the assembler or in-circuit emulator does not output an error message even if an instruction that writes data to this port is described. Moreover, the operation is not affected even if such a program is actually executed on the device.

304



## 24.5 Register File (control register)

(1/2)

| Symbol Name | Attribute | Value    | R/W | Description                                                    |
|-------------|-----------|----------|-----|----------------------------------------------------------------|
| SP          | MEM       | 0.81H    | R/W | Stack pointer                                                  |
| SIO1TS      | FLG       | 0.82H.3  | R/W | Serial interface transmit/receive start flag                   |
| SIO1HIZ     | FLG       | 0.82H.2  | R/W | Serial interface/general-purpose port select flag              |
| SIO1CK1     | FLG       | 0.82H.1  | R/W | Serial interface I/O clock setting flag                        |
| SIO1CK0     | FLG       | 0.82H.0  | R/W | Serial interface I/O clock setting flag                        |
| IFCGOSTT    | FLG       | 0.84H.0  | R   | IF counter gate status detection flag (1: open, 0: close)      |
| PLLUL       | FLG       | 0.85H.0  | R   | PLL unlock FF flag                                             |
| ADCCMP      | FLG       | 0.86H.0  | R   | A/D converter compare result detection flag                    |
| CE          | FLG       | 0.87H.0  | R   | CE pin status detection flag                                   |
| BTM1CK1     | FLG       | 0.89H.3  | R/W | Timer interrupt mode select flag                               |
| BTM1CK0     | FLG       | 0.89H.2  | R/W | Timer interrupt mode select flag                               |
| BTM0CK1     | FLG       | 0.89H.1  | R/W | Timer carry FF mode select flag                                |
| ВТМ0СК0     | FLG       | 0.89H.0  | R/W | Timer carry FF mode select flag                                |
| KSEN        | FLG       | 0.90H.1  | R/W | Key source signal output start flag                            |
| LCDEN       | FLG       | 0.90H.0  | R/W | LCD driver display start flag                                  |
| IFCMD1      | FLG       | 0.92H.3  | R/W | IF counter mode select flag (10: AMIF, 11: setting prohibited) |
| IFCMD0      | FLG       | 0.92H.2  | R/W | IF counter mode select flag (00: BEEP, 01: FMIF)               |
| IFCCK1      | FLG       | 0.92H.1  | R/W | IF counter clock select flag                                   |
| IFCCK0      | FLG       | 0.92H.0  | R/W | IF counter clock select flag                                   |
| ADCCH3      | FLG       | 0.94H.3  | R/W | A/D converter channel select flag (dummy)                      |
| ADCCH2      | FLG       | 0.94H.2  | R/W | A/D converter channel select flag                              |
| ADCCH1      | FLG       | 0.94H.1  | R/W | A/D converter channel select flag                              |
| ADCCH0      | FLG       | 0.94H.0  | R/W | A/D converter channel select flag                              |
| KEYJ        | FLG       | 0.96H.0  | R   | Key input judge flag                                           |
| BTM0CY      | FLG       | 0.97H.0  | R   | Timer carry FF status detection flag                           |
| PLLMD3      | FLG       | 0.0A1H.3 | R/W | PLL mode select flag (dummy: 0)                                |
| PLLMD2      | FLG       | 0.0A1H.2 | R/W | PLL mode select flag (dummy: 0)                                |
| PLLMD1      | FLG       | 0.0A1H.1 | R/W | PLL mode select flag                                           |
| PLLMD0      | FLG       | 0.0A1H.0 | R/W | PLL mode select flag                                           |
| IFCSTRT     | FLG       | 0.0A3H.1 | W   | IF counter count start flag                                    |
| IFCRES      | FLG       | 0.0A3H.0 | W   | IF counter reset flag                                          |
| P0CGIO      | FLG       | 0.0A7H.0 | R/W | P0C input/output select flag                                   |
| PLLRFCK3    | FLG       | 0.0B1H.3 | R/W | PLL reference frequency select flag                            |
| PLLRFCK2    | FLG       | 0.0B1H.2 | R/W | PLL reference frequency select flag                            |
| PLLRFCK1    | FLG       | 0.0B1H.1 | R/W | PLL reference frequency select flag                            |
| PLLRFCK0    | FLG       | 0.0B1H.0 | R/W | PLL reference frequency select flag                            |



## 24.5 Register File (control register)

(2/2)

| Symbol Name | Attribute | Value    | R/W | Description                               |
|-------------|-----------|----------|-----|-------------------------------------------|
| P1ABIO3     | FLG       | 0.0B5H.3 | R/W | P1A₃ input/output select flag             |
| P1ABIO2     | FLG       | 0.0B5H.2 | R/W | P1A₂ input/output select flag             |
| P1ABIO1     | FLG       | 0.0B5H.1 | R/W | P1A <sub>1</sub> input/output select flag |
| P1ABIO0     | FLG       | 0.0B5H.0 | R/W | P1A₀ input/output select flag             |
| P0BBIO3     | FLG       | 0.0B6H.3 | R/W | P0B₃ input/output select flag             |
| P0BBIO2     | FLG       | 0.0B6H.2 | R/W | P0B <sub>2</sub> input/output select flag |
| P0BBIO1     | FLG       | 0.0B6H.1 | R/W | P0B₁ input/output select flag             |
| P0BBIO0     | FLG       | 0.0B6H.0 | R/W | P0B₀ input/output select flag             |
| P0ABIO3     | FLG       | 0.0B7H.3 | R/W | P0A₃ input/output select flag             |
| P0ABIO2     | FLG       | 0.0B7H.2 | R/W | P0A₂ input/output select flag             |
| P0ABIO1     | FLG       | 0.0B7H.1 | R/W | P0A₁ input/output select flag             |
| P0ABIO0     | FLG       | 0.0B7H.0 | R/W | P0A₀ input/output select flag             |

## 24.6 Peripheral Hardware Register

| Symbol Name | Attribute | Value | R/W | Description                                      |
|-------------|-----------|-------|-----|--------------------------------------------------|
| ADCR        | DAT       | 02H   | R/W | A/D converter reference voltage setting register |
| SIO1SFR     | DAT       | 03H   | R/W | Serial interface presettable shift register      |
| PWMR0       | DAT       | 05H   | R/W | PWM₀ data register                               |
| PWMR1       | DAT       | 06H   | R/W | PWM₁ data register                               |
| AR          | DAT       | 40H   | R/W | Address register                                 |
| PLLR        | DAT       | 41H   | R/W | PLL data register                                |
| KSR         | DAT       | 42H   | R/W | Key source data register                         |
| IFC         | DAT       | 43H   | R   | IF counter data register                         |

## 24.7 Others

| Symbol Name | Attribute | Value | Description                                            |
|-------------|-----------|-------|--------------------------------------------------------|
| DBF         | DAT       | 0FH   | Fixed operand value of PUT, GET, and MOVT instructions |
| IX          | DAT       | 01H   | Fixed operand value of INC instruction                 |



## 25. ELECTRICAL SPECIFICATIONS

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

| Parameter                     | Symbol            | Condition                                                                              | Rating                        | Unit |
|-------------------------------|-------------------|----------------------------------------------------------------------------------------|-------------------------------|------|
| Supply voltage                | V <sub>DD</sub>   |                                                                                        | -0.3 to +6.0                  | V    |
| Input voltage                 | Vı                |                                                                                        | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Output voltage                | Vo                | Except P1B <sub>1</sub> through P1B <sub>3</sub> , P0A <sub>2</sub> , P0A <sub>3</sub> | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Output breakdown voltage      | V <sub>BDS1</sub> | P1B <sub>1</sub> -P1B <sub>3</sub>                                                     | 18.0                          | V    |
|                               | V <sub>BDS2</sub> | P0A <sub>2</sub> , P0A <sub>3</sub>                                                    | VDD + 0.3                     | V    |
| High-level output current     | Іон               | 1 pin                                                                                  | -12                           | mA   |
|                               |                   | Total of all pins                                                                      | -20                           | mA   |
| Low-level output current      | lol               | 1 pin                                                                                  | 12                            | mA   |
|                               |                   | Total of all pins                                                                      | 20                            | mA   |
| Operating ambient temperature | TA                |                                                                                        | -40 to +85                    | °C   |
| Storage temperature           | T <sub>stg</sub>  |                                                                                        | -55 to +125                   | °C   |

Caution If the maximum absolute rating of even one of the above parameters is exceeded even momentarily, the quality of the product may degrade. The maximum absolute ratings, therefore, specify values exceeding which the product may be physically damaged. Never exceed these ratings when using the product.

## **Recommended Operating Conditions**

| Parameter                     | Symbol           | Condition                              | MIN. | TYP. | MAX.            | Unit             |
|-------------------------------|------------------|----------------------------------------|------|------|-----------------|------------------|
| Supply voltage                | V <sub>DD1</sub> | When PLL and CPU operate               | 4.5  | 5.0  | 5.5             | V                |
|                               | V <sub>DD2</sub> | When PLL stops and CPU operates        | 3.5  | 5.0  | 5.5             | V                |
| Data retention voltage        | V <sub>DDR</sub> | When crystal oscillation stops         | 2.2  |      | 5.5             | V                |
| Supply voltage rise time      | trise            | $V_{DD} = 0 \rightarrow 4.5 \text{ V}$ |      |      | 500             | ms               |
| Input amplitude               | V <sub>IN1</sub> | VCOL, VCOH                             | 0.5  |      | V <sub>DD</sub> | V <sub>p-p</sub> |
|                               | V <sub>IN2</sub> | AMIFC, FMIFC                           | 0.5  |      | V <sub>DD</sub> | V <sub>p-p</sub> |
| Output breakdown voltage      | V <sub>BDS</sub> | P1B <sub>1</sub> -P1B <sub>3</sub>     |      |      | 16.0            | V                |
| Operating ambient temperature | TA               |                                        | -40  |      | +85             | °C               |



## DC Characteristics (T<sub>A</sub> = -40 to +85 °C, V<sub>DD</sub> = 4.5 to 5.5 V)

| Parameter                         | Symbol            | Condition                                                                                                                                                                                                                                              | MIN.                | TYP. | MAX.    | Unit |
|-----------------------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------|---------|------|
| Supply voltage                    | V <sub>DD1</sub>  | When CPU and PLL operate                                                                                                                                                                                                                               | 4.5                 | 5.0  | 5.5     | V    |
|                                   | V <sub>DD2</sub>  | When CPU operates and PLL stops                                                                                                                                                                                                                        | 3.5                 | 5.0  | 5.5     | V    |
| Supply current                    | I <sub>DD1</sub>  | When CPU and PLL operate X IN pin Sine wave input (fin = 4.5 MHz, Vin = Vdd), Ta = 25 $^{\circ}\text{C}$                                                                                                                                               |                     | 1.2  | 2.4     | mA   |
|                                   | I <sub>DD2</sub>  | When CPU operates and PLL stops HALT instruction used (20 instructions executed every 1 ms) X IN pin sine wave input (fin = 4.5 MHz, V IN = V DD), TA = 25 $^{\circ}$ C                                                                                |                     | 0.45 | 0.90    | mA   |
| Data retention voltage            | V <sub>DDR1</sub> | Power failure detection by timer FF.  During crystal oscillation                                                                                                                                                                                       | 3.5                 |      | 5.5     | ٧    |
|                                   | V <sub>DDR2</sub> | Power failure detection by timer FF.  When crystal oscillation stops                                                                                                                                                                                   | 2.2                 |      | 5.5     | ٧    |
|                                   | V <sub>DDR3</sub> | Retention of data memory (RAM)                                                                                                                                                                                                                         | 2.0                 |      | 5.5     | V    |
| Data retention current            | IDDR1             | When crystal oscillation stops T <sub>A</sub> = 25 °C                                                                                                                                                                                                  |                     | 2    | 15      | μΑ   |
|                                   | IDDR2             | When crystal oscillation stops $V_{DD} = 5.0 \text{ V, T}_{A} = 25 \text{ °C}$                                                                                                                                                                         |                     | 2    | 10      | μΑ   |
| Intermediate-level output voltage | V <sub>OM1</sub>  | $COM_0$ , $COM_1$ $V_{DD} = 5 V$                                                                                                                                                                                                                       | 2.3                 | 2.5  | 2.7     | V    |
| High-level input voltage          | V <sub>IH1</sub>  | P0A <sub>0</sub> -P0A <sub>3</sub> , P0B <sub>0</sub> -P0B <sub>3</sub> , P0C <sub>0</sub> -P0C <sub>3</sub> ,<br>P1A <sub>0</sub> -P1A <sub>3</sub> , P1D <sub>0</sub> -P1D <sub>3</sub><br>CE, INT <sub>0</sub>                                      | 0.8 VDD             |      |         | V    |
|                                   | V <sub>IH2</sub>  | P0D <sub>0</sub> -P0D <sub>3</sub>                                                                                                                                                                                                                     | 0.6 V <sub>DD</sub> |      |         | V    |
| Low-level input voltage           | VIL               | P0A <sub>0</sub> -P0A <sub>3</sub> , P0B <sub>0</sub> -P0B <sub>3</sub> , P0C <sub>0</sub> -P0C <sub>3</sub> ,<br>P0D <sub>0</sub> -P0D <sub>3</sub> , P1A <sub>0</sub> -P1A <sub>3</sub> , P1D <sub>0</sub> -P1D <sub>3</sub><br>CE, INT <sub>0</sub> |                     |      | 0.2 VDD | V    |
| High-level output current         | Іон1              | P0A <sub>0</sub> , P0A <sub>1</sub> , P1A <sub>0</sub> -P1A <sub>3</sub> , P2A <sub>0</sub><br>V <sub>OH</sub> = V <sub>DD</sub> - 2 V, V <sub>DD</sub> = 5 V, T <sub>A</sub> = 25 °C                                                                  | -2.0                | -10  |         | mA   |
|                                   | 1он2              | P0B <sub>0</sub> -P0B <sub>3</sub> , P0C <sub>0</sub> -P0C <sub>3</sub> , P1B <sub>0</sub> ,<br>P1C <sub>0</sub> -P1C <sub>3</sub> VoH = V <sub>DD</sub> = -1 V                                                                                        | -1.0                | -5.0 |         | mA   |
|                                   | Іонз              | LCD <sub>0</sub> -LCD <sub>29</sub> , EO <sub>0</sub> , EO <sub>1</sub> V <sub>OH</sub> = V <sub>DD</sub> - 1 V                                                                                                                                        | -1.0                | -4.0 |         | mA   |
| Low-level output current          | lo <sub>L1</sub>  | P0A <sub>0</sub> -P0A <sub>3</sub> , P1A <sub>0</sub> -P1A <sub>3</sub> , P2A <sub>0</sub><br>Vol. = 2 V, Vdd = 5 V, Ta = 25 °C                                                                                                                        | 5.0                 | 15.0 |         | mA   |
|                                   | lo <sub>L2</sub>  | P0B <sub>0</sub> -P0B <sub>3</sub> , P0C <sub>0</sub> -P0C <sub>3</sub> , P1B <sub>0</sub> ,<br>P1C <sub>0</sub> -P1C <sub>3</sub> V <sub>OL</sub> = 1 V                                                                                               | 1.0                 | 7.0  |         | mA   |
|                                   | <b>І</b> оьз      | LDC <sub>0</sub> -LDC <sub>29</sub> , EO <sub>0</sub> , EO <sub>1</sub> Vol = 1 V                                                                                                                                                                      | 1.0                 | 3.5  |         | mA   |
|                                   | lo <sub>L4</sub>  | P1B <sub>1</sub> -P1B <sub>3</sub> VoL = 1 V                                                                                                                                                                                                           | 1.0                 | 2.0  |         | mA   |
| High-level input current          | I <sub>IH1</sub>  | With VCOH pulled down V <sub>IH</sub> = V <sub>DD</sub>                                                                                                                                                                                                | 0.1                 | 0.8  |         | mA   |
|                                   | I <sub>IH2</sub>  | With VCOL pulled down $V_{IH} = V_{DD}$                                                                                                                                                                                                                | 0.1                 | 0.8  |         | mA   |
|                                   | I <sub>IH3</sub>  | With X <sub>IN</sub> pulled down V <sub>IH</sub> = V <sub>DD</sub>                                                                                                                                                                                     | 0.1                 | 1.3  |         | mA   |
|                                   | I <sub>IH4</sub>  | With P0D <sub>0</sub> through P0D <sub>3</sub> pulled down $V_{IH} = V_{DD}$                                                                                                                                                                           | 0.05                | 0.13 | 0.30    | mA   |
| Output off leakage current        | IL1               | P0A <sub>2</sub> , P0A <sub>3</sub> V <sub>OH</sub> = V <sub>DD</sub>                                                                                                                                                                                  |                     |      | 500     | nA   |
|                                   | IL2               | P1B <sub>1</sub> -P1B <sub>3</sub> VoH = 16 V                                                                                                                                                                                                          |                     |      | 500     | nA   |
|                                   | Іцз               | EO <sub>0</sub> , EO <sub>1</sub> V <sub>OH</sub> = V <sub>DD</sub> , V <sub>OL</sub> = 0 V                                                                                                                                                            |                     |      | ±100    | nA   |



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

| Parameter                 | Symbol           | Condition                     |                                              | MIN. | TYP. | MAX. | Unit |
|---------------------------|------------------|-------------------------------|----------------------------------------------|------|------|------|------|
| Operating frequency       | f <sub>IN1</sub> | VCOL MF mode, sine wave input | $V_{IN} = 0.2 V_{p-p}$                       | 0.5  |      | 30   | MHz  |
|                           | f <sub>IN2</sub> | VCOL HF mode, sine wave input | VIN = 0.2 V <sub>p-p</sub>                   | 5    |      | 40   | MHz  |
|                           | fınз             | VCOH sine wave input          | $V_{IN} = 0.2 V_{p-p}$                       | 9    |      | 150  | MHz  |
|                           | fin4             | AMIFC sine wave input         | $V_{IN} = 0.3 V_{p-p}$                       | 0.1  |      | 1    | MHz  |
|                           | f <sub>IN5</sub> | AMIFC sine wave input         | VIN = 0.05 V <sub>p-p</sub>                  | 0.44 |      | 0.46 | MHz  |
|                           | fin6             | FMIFC sine wave input         | $V_{IN} = 0.3 V_{p-p}$                       | 5    |      | 15   | MHz  |
|                           | fin7             | FMIFC sine wave input         | $V_{IN} = 0.06 V_{p-p}$                      | 10.5 |      | 10.9 | MHz  |
| AD conversion resolution  |                  |                               |                                              |      |      | 6    | bit  |
| AD conversion total error |                  |                               | $T_A = -10 \text{ to } +50 ^{\circ}\text{C}$ |      | ±1   | ±1.5 | LSB  |

## **Reference Characteristics**

| Parameter                 | Symbol           | Condition                                                                                                                            | MIN. | TYP. | MAX. | Unit |
|---------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|
| Supply current            | I <sub>DD3</sub> | When CPU and PLL operate VCOH sine wave input fin = 150 MHz, Vin = 0.3 V <sub>P-P</sub> $V_{DD} = 5 \text{ V, } T_A = 25 \text{ °C}$ |      | 15   |      | mA   |
| High-level output current | Іонз             | COM <sub>0</sub> , COM <sub>1</sub> $V_{OH} = V_{DD} - 1 V$                                                                          |      | -0.2 |      | mA   |
| Intermediate-level        | Іом1             | COM <sub>0</sub> , COM <sub>1</sub> $V_{OM} = V_{DD} - 1 V$                                                                          |      | -20  |      | μΑ   |
| output current            | Іом2             | COM <sub>0</sub> , COM <sub>1</sub> V <sub>OM</sub> = 1 V                                                                            |      | 20   |      | μΑ   |
| Low-level output current  | lo <sub>L5</sub> | COMo, COM1 VoL = 1 V                                                                                                                 |      | 0.2  |      | mA   |



## 26. PACKAGE

Package of mass-produced model

## 80 PIN PLASTIC QFP (14×20)



detail of lead end



## NOTE

Each lead centerline is located within 0.15 mm (0.006 inch) of its true position (T.P.) at maximum material condition.

| ITEM | MILLIMETERS            | INCHES                    |
|------|------------------------|---------------------------|
| Α    | 23.2±0.2               | $0.913^{+0.009}_{-0.008}$ |
| В    | 20.0±0.2               | 0.787+0.009               |
| С    | 14.0±0.2               | 0.551+0.009               |
| D    | 17.2±0.2               | 0.677±0.008               |
| F    | 1.0                    | 0.039                     |
| G    | 1.8                    | 0.031                     |
| Н    | 0.35±0.10              | 0.014+0.004               |
| ı    | 0.15                   | 0.006                     |
| J    | 0.8 (T.P.)             | 0.031 (T.P.)              |
| K    | 1.6±0.2                | 0.063±0.008               |
| L    | 0.8±0.2                | $0.031^{+0.009}_{-0.008}$ |
| М    | $0.15^{+0.10}_{-0.05}$ | $0.006^{+0.004}_{-0.003}$ |
| N    | 0.10                   | 0.004                     |
| Р    | 2.7                    | 0.106                     |
| Q    | 0.125±0.075            | 0.005±0.003               |
| R    | 5°±5°                  | 5°±5°                     |
| S    | 3.0 MAX.               | 0.119 MAX.                |

S80GF-80-3B9-3

Caution The ES model differs from the mass-produced model in package and materials. Refer to the package drawing of the ES model.

## Package of ES model

## ES 80-PIN CERAMIC QFP (REFERENCE) (UNIT: mm)





## Cautions

- The leads are diagonally molded on the bottom surface.
- 2. Because cutting of the tip of the lead is not subject to quality control, the lead length is not specified.



#### 27. RECOMMENDED SOLDERING CONDITIONS

Solder the  $\mu$ PD17016 and 17017 under the following recommended conditions.

For details of the recommended soldering conditions, refer to Information document **Semiconductor Device Mounting Technology Manual (C10535E)**.

For the soldering methods and conditions other than those recommended, consult NEC.

Table 27-1. Soldering Conditions of Surface Mount Type

 $\mu$ PD17016GF-xxx-3B9: 80-pin plastic QFP (14  $\times$  20 mm)  $\mu$ PD17017GF-xxx-3B9: 80-pin plastic QFP (14  $\times$  20 mm)

| Soldering Method | Soldering Condition                                                                                                                                                                                                                                                                                                                                                     | Symbol of<br>Recommended<br>Soldering Condition |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| Infrared reflow  | Package peak temperature: 235 °C, Time: 30 seconds max. (210 °C min.), Number of times: 2 max., Number of days: 7 <sup>Note</sup> (After this, prebaking at 125 °C for 20 hours is necessary.) <pre><precaution> Products other than those supplied in heat-resistance tray (magazine, taping, and heat-labile tray) cannot be baked in their packs.</precaution></pre> | IR35-207-2                                      |
| VPS              | Package peak temperature: 215 °C, Time: 40 seconds max. (200 °C min.), Number of times: 2 max., Number of days: 7 <sup>Note</sup> (After this, prebaking at 125 °C for 20 hours is necessary.) <pre><precaution> Products other than those supplied in heat-resistance tray (magazine, taping, and heat-labile tray) cannot be baked in their packs.</precaution></pre> | VP15-207-2                                      |
| Wave soldering   | Solder bath temperature: 260 °C max., Time: 10 seconds max., Number of times: 1, Preheating temperature: 120 °C max. (package surface temperature), Number of days: 7 <sup>Note</sup> (After this, prebaking at 125 °C for 20 hours is necessary.)                                                                                                                      | WS60-207-1                                      |
| Partial heating  | Pin temperature: 300 °C max., Time: 3 seconds max. (per side of device)                                                                                                                                                                                                                                                                                                 | -                                               |

**Note** The number of days for which the device can be left at 25 °C, 65 % RH max. after the dry pack has been opened.

Caution Do not use two or more soldering methods in combination (except the partial heating method).

#### APPENDIX A. NOTE ON CONNECTING CRYSTAL RESONATOR

When using the system clock oscillation circuit, the following points must be noted in wiring the portion indicated by the dotted line in the figure below to prevent adverse influence from wiring capacitance.

- · Keep the wiring length as short as possible.
- If capacitances C1 and C2 are too high, the oscillation start characteristic may be degraded or the current consumption may increase.
- Generally, connect the trimmer capacitor for adjusting the oscillation frequency to the XIN pin. Depending on the crystal resonator used, however, the oscillation stabilization differs. Therefore, evaluate the crystal resonator actually to be used.
- The crystal frequency cannot be accurately adjusted because of probe capacitance if an emulation probe is connected to the Xout or Xin pin. Adjust the frequency while measuring the LCD drive waveform (125 Hz) or VCO oscillation frequency.





## APPENDIX B. DIFFERENCES AMONG $\mu$ PD17016, 17017, 17003A, 17005, AND 17010

## (1) Hardware

|                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1                                                                                                               | 1                            |  |
|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|------------------------------|--|
| Item                                                                     | μPD17010                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | μPD17003A                                                                                                       | μPD17005                     |  |
| ROM                                                                      | 16 KB<br>(7932 × 16 bits)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 8 KB<br>(3836 × 16 bits)                                                                                        | 16 KB<br>(7932 × 16 bits)    |  |
| RAM                                                                      | 432 × 4 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 320 × 4 bits                                                                                                    | 432 × 4 bits                 |  |
| Output port                                                              | 13 pins (+30: LCD segment pins)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 9 pins (+30: LCD segment pins)                                                                                  |                              |  |
| Control register                                                         | 41 × 4 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 33 × 4 bits                                                                                                     |                              |  |
| General register pointer                                                 | 5 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 4 bits                                                                                                          |                              |  |
| Stack level                                                              | 9 levels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 7 levels                                                                                                        |                              |  |
| Serial interface                                                         | 2 modes (3 channels): serial I/O mode, I <sup>2</sup> C bu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | s mode                                                                                                          |                              |  |
|                                                                          | <ul> <li>SIO0 clock<br/>37.5, 75, 112.5, 225 kHz</li> <li>SIO1 clock<br/>External, 37.5, 75, 450 kHz</li> <li>Hysteresis characteristics for SCL, SDA,<br/>SCK<sub>0</sub>, SCK<sub>1</sub>, SI<sub>0</sub>, and SI<sub>1</sub> pins</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <ul> <li>SIO1 clock</li> <li>75, 150, 225, 450 kł</li> <li>SIO2 clock</li> <li>External, 75, 150, 45</li> </ul> |                              |  |
| D/A converter frequency                                                  | 4394.5 Hz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 878.9 Hz                                                                                                        |                              |  |
| D/A converter output (PWM)                                               | 3 channels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                 |                              |  |
| Interrupt                                                                | 6 sources     External: 1 source (INTo pin)     Internal: 4 sources (TM, BTM1, SIOO, IFC)     External/internal: 1 source (INTo pin or overflow of timer/counter)      Interrupt priority (vector address)     1. (6H) INTo pin     2. (5H) INTo pin     2. (5H) INTo pin     3. (4H) 12-bit timer     4. (3H) Basic timer 1     5. (2H) Serial interface 0     6. (1H) Frequency counter      Automatic saving of system register (3 levels) (WR, BANK, RP, PSWORD)      Address change of IRQxxx flag      S sources     External: 2 sources (INTo Internal: 3 sources (TM, INTo Internal: 3 sources (TM, Internal: 3 sources (INTo Int |                                                                                                                 | ctor address) face 1 counter |  |
|                                                                          | <ul> <li>(1, 5, 100, 250 ms)</li> <li>Basic timer 1 interrupt</li> <li>(1, 5, 100, 250 ms)</li> <li>12-bit timer</li> <li>(10 μs to 4095 ms)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | (1, 5, 100, 250 ms) • Timer interrupt (1, 5, 100, 250 ms)                                                       |                              |  |
| Frequency counter                                                        | Frequency measurement (IF measurement) and external gate width measurement functions selectable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                 |                              |  |
| Clock generator port (CGP)                                               | CGP output: 1 line SG (Signal Generator) function VDP (Variable Duty Pulse) function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                 |                              |  |
| PLL frequency synthesizer phase comparator                               | Provided (Unlock detection by program. Unlock FF delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | time selectable)                                                                                                |                              |  |
| Operational amplifier for<br>PLL frequency synthesizer<br>lowpass filter | None Provided                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                 |                              |  |
| Package                                                                  | 80-pin plastic QFP (14 × 20 mm)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                 |                              |  |



| μPD17016                                                                   | μPD17017                   |  |  |
|----------------------------------------------------------------------------|----------------------------|--|--|
| 8 KB                                                                       | 16 KB                      |  |  |
| (3836 × 16 bits)                                                           | (7932 × 16 bits)           |  |  |
| 320 × 4 bits                                                               | 432 × 4 bits               |  |  |
| 9 pins (+8: LCD segm                                                       | ent pins)                  |  |  |
| 19 × 4 bits                                                                |                            |  |  |
| 4 bits                                                                     |                            |  |  |
| 7 levels                                                                   |                            |  |  |
| 1 channel: serial I/O m                                                    | node                       |  |  |
| SIO1 clock     External, 75, 150, 45                                       | 50 kHz                     |  |  |
| 878.9 Hz                                                                   |                            |  |  |
| 2 channels                                                                 |                            |  |  |
| 2 sources     External: 1 source (     Internal: 1 source (                | ' '                        |  |  |
| • Interrupt priority (vec<br>1. (5H) INT <sub>0</sub> pin<br>2. (3H) Timer | ctor address)              |  |  |
| Automatic saving of s     (BANK, IXE)                                      | system register (4 levels) |  |  |
| • Timer carry (1, 5, 100, 250 ms) • Timer interrupt (1, 5, 100, 250 ms)    |                            |  |  |
| Frequency measurement function only                                        |                            |  |  |
| None (BEEP output pro                                                      | ovided)                    |  |  |
| Internal (without unlock function)                                         | FF delay time select       |  |  |
| None                                                                       |                            |  |  |
| 80-pin plastic QFP (14                                                     | × 20 mm)                   |  |  |



## (2) Software

| Item                                                                                                                                 | μPD17010                                                                                              | μPD17003A                                                                                                                                                                                    | μPD17005                                               | μPD17016                             | μPD17017                  |
|--------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------|---------------------------|
| Setting of LCD segment output or output port of LCD <sub>22</sub> /P0E <sub>0</sub> through LCD <sub>29</sub> /P0F <sub>3</sub> pins |                                                                                                       | Write (POKE) instruction and flag manipulation embedded macroinstructions can be used.                                                                                                       |                                                        |                                      | oftware macro<br>ce file. |
| Setting of output port or<br>PWM output of P1B <sub>1</sub> /PWM <sub>0</sub><br>and P1B <sub>2</sub> /PWM <sub>1</sub> pin          |                                                                                                       |                                                                                                                                                                                              |                                                        |                                      |                           |
| Interrupt request lag                                                                                                                | Write (POKE) instruction and flag manipulation embedded macroinstructions can be used.                | If write (POKE) inserior occurs during If flag manipulation macroinstruction is occurs during assessible Subjected flags IRQIFC IRQSIO1 IRQTM IRQ1 IRQ0 To write above flag library IRQ.MAC. | g assembly.<br>In embedded<br>Is used, error<br>embly. |                                      |                           |
| Enabling interrupt                                                                                                                   | Write (POKE) instr                                                                                    | uction and flag mani                                                                                                                                                                         | pulation embedded                                      |                                      |                           |
| Level judge of INT₀ pin                                                                                                              | Write (POKE) instr                                                                                    | uction and embedded<br>an be used.                                                                                                                                                           | d macroinstructions                                    |                                      |                           |
| IF counter control register                                                                                                          | Read (PEEK) instruction is used. At this time, "0" is always read. SETn instruction can be also used. | macroinstructions expanded to SETn                                                                                                                                                           |                                                        |                                      | · ·                       |
| BEEP output setting                                                                                                                  | None                                                                                                  |                                                                                                                                                                                              |                                                        | Manipulated by so supplied with devi |                           |

## (3) Development tools

|            | Item            | μPD17010   | μPD17003A    | μPD17005 | μPD17016     | μPD17017     |
|------------|-----------------|------------|--------------|----------|--------------|--------------|
| Hardware   | SE board        | SE-17010   |              |          |              |              |
|            | Emulation probe | EP-17003GF |              |          |              |              |
| Software   | Device file     | AS17010    | AS17003      | AS17005  | AS17016      |              |
|            | Macro library   | None       | • IFCSET.LIB |          | • IFCSET.LIB | • IFCSET.LIB |
|            |                 |            | • IRQ.MAC    |          | • D17016.INC | • D17017.INC |
| One-time F | PROM            | μPD17P010  | μPD17P005    |          |              |              |



## (4) Notes on reserved word names

The reserved words of the control registers of the  $\mu$ PD17016 and 17017 are different from some reserved words of the  $\mu$ PD17003A and 17005.

The following table shows the differences in the reserved words between the  $\mu$ PD17016/17017 and  $\mu$ PD17003A/17005. Note that this table shows only the different reserved words.

| Item                      | μPD17003A              | μPD17005 | μPD17016 | μPD17017 |  |
|---------------------------|------------------------|----------|----------|----------|--|
| Timer                     | TMMD2 TMMD1            |          | BTM1CK1  |          |  |
|                           |                        |          | BTM1CK0  |          |  |
|                           |                        |          | BTM0CK1  |          |  |
|                           |                        |          | BTM0CK0  |          |  |
|                           | TMCY                   |          | BTM0CY   |          |  |
| PLL frequency synthesizer | PLULDLY3               |          | None     |          |  |
|                           | PLULDLY2               |          |          |          |  |
|                           | PLULDLY1               |          |          |          |  |
|                           | PLULDLY0               |          |          |          |  |
|                           | PLLRFMD3               |          | PLLRFCK3 |          |  |
|                           | PLLRFMD2               |          | PLLRFCK2 |          |  |
|                           | PLLRFMD1               |          | PLLRFCK1 |          |  |
|                           | PLLRFMD0               |          | PLLRFCK0 |          |  |
| D/A converter             | PWM2ON                 | None     |          |          |  |
|                           | PWM1ON <sup>Note</sup> |          |          |          |  |
|                           | PWM0ON <sup>Note</sup> |          |          |          |  |
|                           | CGPON                  |          |          |          |  |
| LCD controller/driver     | P0YON P0XON P0EONNote  |          | None     |          |  |
|                           |                        |          |          |          |  |
|                           |                        |          |          |          |  |
|                           | P0F0N <sup>Note</sup>  |          |          |          |  |
| Frequency counter         | IFCG                   |          | IFCGOSTT |          |  |
| Serial interface          | SIO2TS                 |          | SIO1TS   |          |  |
|                           | SIO2HIZ                |          | SIO1HIZ  |          |  |
|                           | SIO2CK1                |          | SIO1CK1  |          |  |
|                           | SIO2CK0                |          | SIO1CK0  |          |  |
|                           | SIO1CH                 |          | None     |          |  |
|                           | SB                     |          |          |          |  |
|                           | SIO1MS<br>SIO1TX       |          |          |          |  |
|                           |                        |          |          |          |  |
|                           | SBACK                  |          |          |          |  |

**Note** These reserved words are manipulated by software macros with the  $\mu$ PD17016 and 17017.



| Item             | μPD17003A            | μPD17005 | μPD17016 | μPD17017 |
|------------------|----------------------|----------|----------|----------|
| Serial interface | SIO1NWT              | SIO1NWT  |          |          |
|                  | SIO1WRQ1             |          |          |          |
|                  | SIO1WRQ0             | SIO1WRQ0 |          |          |
|                  | SIO1SF8              | SIO1SF8  |          |          |
|                  | SIO1SF9              |          |          |          |
|                  | SBBSY                |          |          |          |
|                  | SBSTT                |          |          |          |
|                  | SIO1IMD3             |          |          |          |
|                  | SIO1IMD2             |          |          |          |
|                  | SIO1IMD1             |          |          |          |
|                  | SIO1IMD0             |          |          |          |
|                  | SIO1CK3              |          |          |          |
|                  | SIO1CK2              |          |          |          |
|                  | SIO1CK1              |          |          |          |
|                  | SIO1CK0              |          |          |          |
| Interrupt        | INT1                 |          | None     |          |
|                  | INT0 <sup>Note</sup> |          |          |          |
|                  | IEG1                 | IEG1     |          |          |
|                  | IEG0                 |          |          |          |
|                  | IPIFC                | IPIFC    |          |          |
|                  | IPSIO1               |          |          |          |
|                  | IPTMNote             | IPTMNote |          |          |
|                  | IP1                  | IP1      |          |          |
|                  | IP0                  |          |          |          |
|                  | IRQIFC               |          |          |          |
|                  | IRQSIO1 IRQTMNote    |          |          |          |
|                  |                      |          |          |          |
|                  | IRQ1                 |          |          |          |
|                  | IRQ0 <sup>Note</sup> |          |          |          |

**Note** These reserved words are manipulated by software macros with the  $\mu$ PD17016 and 17017.



## APPENDIX C. DEVELOPMENT TOOLS

The following development tools are available to support development of the program of the  $\mu$ PD17016 and 17017.

#### Hardware

| Name                                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| In-circuit emulator  ( IE-17K,   IE-17K-ETNote 1,   EMU-17KNote 2            | IE-17K, IE-17K-ET, and EMU-17K are in-circuit emulators that can be commonly used with any model in 17K Series. IE-17K and IE-17K-ET are connected to host machine, which is PC-9800 series or IBM PC/AT <sup>TM</sup> , with RS-232-C. EMU-17K is mounted to expansion slot of PC-9800 series. When these in-circuit emulators are used in combination with system evaluation board (SE board) dedicated to each model, they operate as emulators corresponding to that model. When man-machine interface software <i>SIMPLEHOST</i> ® is used, a more sophisticated debugging environment can be created.  EMU-17K has a function for checking the contents of data memory real-time. |
| SE board<br>(SE-17010)                                                       | SE-17010 is SE board for $\mu$ PD17016 and 17017. This SE board alone can be used to evaluate system or in combination with in-circuit emulator for debugging.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Emulation probe<br>(EP-17003GF)                                              | EP-17003GF is emulation probe for $\mu$ PD17016GF and 17017GF. It connects SE board and target system when used with EV-9200G-80 <sup>Note 3</sup> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Conversion socket (EV-9200G-80 <sup>Note 3</sup> )                           | EV-9200G-80 is conversion socket for 80-pin plastic QFP (14 $\times$ 20 mm) and is used to connect EP-17003GF and target system.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| PROM programmer  (AF-9703Note 4, AF-9704Note 4, AF-9705Note 4, AF-9706Note 4 | AF-9703, AF-9704, AF-9705, and AF-9706 are PROM programmers corresponding to $\mu$ PD17P005. They can program the $\mu$ PD17P005 when connected to program adapter AF-9803.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Program adapter (AF-9803 <sup>Note 4</sup> )                                 | AF-9803 is adapter for programming $\mu$ PD17P005, and is used in combination with AF-9703, AF-9704, AF-9705, or AF-9706.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

- Notes 1. Low-cost model: external power supply type
  - 2. This is a product by I.C Corp. For details, consult I.C Corp. (Tokyo, 03-3447-3793)
  - 3. One EV-9200G-80 is provided with the EP-17003GF. Five EV-9200G-80s are also available as a set.
  - **4.** These are products of Ando Electric Co., Ltd. For details, consult Ando Electric Co, Ltd. (Tokyo, 03-3733-1163).

319



#### **Software**

| Name                          | Description                                                                                                      | Host Machine                   | 0                              | S       | Supply<br>Media | Order Code    |           |               |  |       |               |
|-------------------------------|------------------------------------------------------------------------------------------------------------------|--------------------------------|--------------------------------|---------|-----------------|---------------|-----------|---------------|--|-------|---------------|
| 17K series assembler (AS17K)  | AS17K is an assembler that can be commonly used with                                                             | PC-9800 series                 | MS-DOS <sup>TM</sup>           |         | 5"2HD           | μS5A10AS17K   |           |               |  |       |               |
|                               | any model of 17K series.                                                                                         |                                |                                |         | 3.5"2HD         | μS5A13AS17K   |           |               |  |       |               |
|                               | To develop program of $\mu$ PD17016 and 17017, this                                                              | IBM PC/AT                      | PC DOS                         | TM      | 5"2HC           | μS7B10AS17K   |           |               |  |       |               |
|                               | AS17K is used in combination with device file (AS17016).                                                         |                                |                                |         | 3.5"2HC         | μS7B13AS17K   |           |               |  |       |               |
| Device file<br>(AS17016)      |                                                                                                                  | PC-9800 series                 | MS-DOS                         |         | 5"2HD           | μS5A10AS17016 |           |               |  |       |               |
| (1017010)                     |                                                                                                                  | It is used in combination with | It is used in combination with |         |                 |               | 3.5"2HC   | μS5A13AS17016 |  |       |               |
|                               |                                                                                                                  |                                |                                |         |                 |               | IBM PC/AT | PC DOS        |  | 5"2HC | μS7B10AS17016 |
|                               |                                                                                                                  |                                |                                |         | 3.5"2HC         | μS7B13AS17016 |           |               |  |       |               |
| Support software (SIMPLEHOST) | SIMPLEHOST is software that serves as man-machine                                                                | PC-9800 series                 | MS-DOS                         | Windows | 5"2HD           | μS5A10IE17K   |           |               |  |       |               |
| (Omm ZETTOOT)                 | interface on Windows <sup>TM</sup> when program is developed by using in-circuit emulator and personal computer. |                                |                                |         | 3.5"2HD         | μS5A13IE17K   |           |               |  |       |               |
|                               |                                                                                                                  | IBM PC/AT                      | PC DOS                         |         | 5"2HC           | μS7B10IE17K   |           |               |  |       |               |
|                               |                                                                                                                  |                                |                                |         | 3.5"2HC         | μS7B13IE17K   |           |               |  |       |               |

**Remark** The following versions of OSs are supported.

| os      | Version                   |
|---------|---------------------------|
| MS-DOS  | Ver.3.30 to Ver.5.00ANote |
| PC DOS  | Ver.3.1 to Ver.5.0Note    |
| Windows | Ver.3.0 to Ver.3.1        |

Note MS-DOS Ver.5.00/5.00A and PC DOS Ver.5.0 have a task swap function, but this function cannot be used with this software.

[MEMO]



## NOTES FOR CMOS DEVICES -

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

## (2) HANDLING OF UNUSED INPUT PINS FOR CMOS

Note: No connection for CMOS device inputs can be cause of malfunction. If no connection is provided to the input pins, it is possible that an internal input level may be generated due to noise, etc., hence causing malfunction. CMOS device 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.

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

Mountain View, California Tel: 800-366-9782 Fax: 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.1.

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

France Tel: 01-30-67 58 00 Fax: 01-30-67 58 99

## **NEC Electronics (France) S.A.**

Spain Office Madrid, Spain Tel: 01-504-2787 Fax: 01-504-2860

## **NEC Electronics (Germany) GmbH**

Scandinavia Office Taeby Sweden Tel: 8-63 80 820 Fax: 8-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.

United Square, Singapore 1130 Tel: 253-8311

Fax: 250-3583

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

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

## **NEC do Brasil S.A.**

Sao Paulo-SP, Brasil Tel: 011-889-1680 Fax: 011-889-1689

J96. 3

**SIMPLEHOST** is a registered trademark of NEC Corporation. MS-DOS and Windows are trademarks of Microsoft Corporation.

PC/AT and PC DOS are trademarks of IBM Corporation.

The export of this product from Japan is regulated by the Japanese government. To export this product may be prohibited without governmental license, the need for which must be judged by the customer. The export or re-export of this product from a country other than Japan may also be prohibited without a license from that country. Please call an NEC sales representative.

No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Corporation. NEC Corporation assumes no responsibility for any errors which may appear in this document.

NEC Corporation does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from use of a device described herein or any other liability arising from use of such device. No license, either express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Corporation or others.

While NEC Corporation has been making continuous effort to enhance the reliability of its semiconductor devices, the possibility of defects cannot be eliminated entirely. To minimize risks of damage or injury to persons or property arising from a defect in an NEC semiconductor device, customers must incorporate sufficient safety measures in its design, such as redundancy, fire-containment, and anti-failure features.

NEC devices are classified into the following three quality grades:

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

Standard: Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots

Special: Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support)

Specific: Aircrafts, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems or medical equipment for life support, etc.

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

Anti-radioactive design is not implemented in this product.