

# mos integrated circuit μPD17145, 17147, 17149, 17145(A), 17147(A), 17149(A)

# SMALL GENERAL-PURPOSE 4 BIT SINGLE-CHIP MICROCONTROLLER

The  $\mu$ PD17145,  $\mu$ PD17147,  $\mu$ PD17149,  $\mu$ PD17145(A),  $\mu$ PD17147(A), and  $\mu$ PD17149(A) are 4-bit single-chip microcontrollers containing an 8-bit A/D converter (four channels), three timers, and a serial interface.

For the CPU, the  $\mu$ PD17145,  $\mu$ PD17147,  $\mu$ PD17149,  $\mu$ PD17145(A),  $\mu$ PD17147(A), and  $\mu$ PD17149(A) use general registers. They can perform operations directly on data memory and transfer data directly between memory, allowing programming to be done efficiently. Each instruction is 16 bits (one word) long.

Since the  $\mu$ PD17145,  $\mu$ PD17147,  $\mu$ PD17149,  $\mu$ PD17145(A),  $\mu$ PD17147(A), and  $\mu$ PD17149(A) have an on-chip A/D converter and serial interface, they are suitable for electronic control in various applications such as electric home appliances. The  $\mu$ PD17P149, a one-time PROM product, is available for evaluation of the  $\mu$ PD17145,  $\mu$ PD17147,  $\mu$ PD17149,  $\mu$ PD17145(A),  $\mu$ PD17147(A), and  $\mu$ PD17149(A) and for small-scale production of general electronic equipment.

The following user's manual completely describes the functions of the  $\mu$ PD17145,  $\mu$ PD17147,  $\mu$ PD17149,  $\mu$ PD17145(A),  $\mu$ PD17147(A), and  $\mu$ PD17149(A). Be sure to read it before designing an application system.  $\mu$ PD17145 Sub-Series User's Manual: U10261E

#### **FEATURES**

• 17K architecture: General registers, 16-bit instructions

• Program memory (ROM):  $\mu$ PD17145: 2K bytes (1024 × 16 bits)

 $\mu$ PD17147: 4K bytes (2048 × 16 bits)  $\mu$ PD17149: 8K bytes (4096 × 16 bits)

• Data memory (RAM): 110 × 4 bits

External interrupt:
 1 line (INT pin, with sensor input)

• Instruction execution time: 2  $\mu$ s (when fx = 8 MHz, ceramic oscillation)

8-bit A/D converter: 4 channels

Absolute accuracy: ±1.5 LSB or lower (VDD = 4.0 to 5.5 V)

Timer function: 3 channels

• Serial interface: 1 channel (three-wire synchronous mode)

• POC circuit (mask option)

• Supply voltage:  $V_{DD} = 2.7 \text{ to } 5.5 \text{ V (when fx} = 400 \text{ kHz to 2 MHz)}$ 

 $V_{DD} = 4.5 \text{ to } 5.5 \text{ V (when fx} = 400 \text{ kHz to } 8 \text{ MHz)}$ 

#### **APPLICATIONS**

 $\mu$ PD17145,  $\mu$ PD17147, and  $\mu$ PD17149 : Electric appliances, battery chargers, cameras, electronic

measuring instruments

 $\mu$ PD17145(A),  $\mu$ PD17147(A), and  $\mu$ PD17149(A) : Electrical equipment for automobile

In this manual, the product described is the  $\mu$ PD17149 unless otherwise specified.

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



#### **ORDERING INFORMATION**

| Part number                                | Package                             | Quality grade |
|--------------------------------------------|-------------------------------------|---------------|
| $\mu$ PD17145CT- $\times\times$            | 28-pin plastic shrink DIP (400 mil) | Standard      |
| $\mu$ PD17145GT- $\times\!\times\!$        | 28-pin plastic SOP (375 mil)        | Standard      |
| $\mu$ PD17147CT- $\times\!\times\!$        | 28-pin plastic shrink DIP (400 mil) | Standard      |
| $\mu$ PD17147GT- $\times\!\!\times\!\!$    | 28-pin plastic SOP (375 mil)        | Standard      |
| $\mu$ PD17149CT- $\times\!\times\!$        | 28-pin plastic shrink DIP (400 mil) | Standard      |
| $\mu$ PD17149GT- $	imes$ $	imes$           | 28-pin plastic SOP (375 mil)        | Standard      |
| $\mu$ PD17145CT(A)- $\times$ $\times$      | 28-pin plastic shrink DIP (400 mil) | Special       |
| $\mu$ PD17145GT(A)- $\times\!\!\times\!\!$ | 28-pin plastic SOP (375 mil)        | Special       |
| $\mu$ PD17147CT(A)- $\times$ $\times$      | 28-pin plastic shrink DIP (400 mil) | Special       |
| $\mu$ PD17147GT(A)- $\times\!\!\times\!\!$ | 28-pin plastic SOP (375 mil)        | Special       |
| $\mu$ PD17149CT(A)- $\times$ $\times$      | 28-pin plastic shrink DIP (400 mil) | Special       |
| $\mu$ PD17149GT(A)-×××                     | 28-pin plastic SOP (375 mil)        | Special       |

Remark xxx is a ROM code

The  $\mu$ PD17145,  $\mu$ PD17147, and  $\mu$ PD17149 differ from those suffixed with (A) in quality grades only.

Please refer to "Quality Grades on NEC Semiconductor Devices" (Document No. C11531E) published by NEC Corporation to know the specification of quality grade on the devices and its recommended applications.



#### **FUNCTIONS**

| Product                          | μPD17145                                                                                                                                    | μPD17147                                                             | μPD17149                      |  |  |  |  |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------|--|--|--|--|
| ROM                              | 2K bytes (1024 × 16 bits)                                                                                                                   | 4K bytes (2048 × 16 bits)                                            | 8K bytes (4096 × 16 bits)     |  |  |  |  |
| RAM                              | 110 × 4 bits                                                                                                                                | 10 × 4 bits                                                          |                               |  |  |  |  |
| Stack                            | 5 address stacks, 3 interrupt st                                                                                                            | acks                                                                 |                               |  |  |  |  |
| Number of I/O ports              | 23 { • 20 I/O ports                                                                                                                         | IT pin <sup>Note</sup> )                                             |                               |  |  |  |  |
| A/D converter input              | 4 channels (shared with ports) (VDD): 4.0 to 5.5 V)                                                                                         | with an absolute accuracy of ±1.                                     | 5 LSB or less (supply voltage |  |  |  |  |
| Timer                            | timer.)                                                                                                                                     | or 8-bit timer counter (They can r 7-bit basic interval timer (can b | •                             |  |  |  |  |
| Serial interface                 | 1 channel (3-wire type)                                                                                                                     |                                                                      |                               |  |  |  |  |
| Interrupt                        | Up to 3 levels of multiple hardware interrupt     1 external interrupt     (INT)                                                            |                                                                      |                               |  |  |  |  |
| Execution time of an instruction | 2 $\mu$ s (at f <sub>X</sub> = 8 MHz, ceramic os                                                                                            | scillation)                                                          |                               |  |  |  |  |
| Standby function                 | STOP/HALT                                                                                                                                   |                                                                      |                               |  |  |  |  |
| POC circuit                      | Mask option (Can be used in an application circuit where V <sub>DD</sub> is 5 V ±10 % and the clock frequency ranges from 400 kHz to 4 MHz) |                                                                      |                               |  |  |  |  |
| Operating supply voltage         | <ul> <li>V<sub>DD</sub> = 2.7 to 5.5 V (at 400 kHz to 2 MHz)</li> <li>V<sub>DD</sub> = 4.5 to 5.5 V (at 400 kHz to 8 MHz)</li> </ul>        |                                                                      |                               |  |  |  |  |
| Package                          | 28-pin plastic shrink DIP (400 mil)     28-pin plastic SOP (375 mil)                                                                        |                                                                      |                               |  |  |  |  |
| One-time PROM                    | μPD17P149                                                                                                                                   |                                                                      |                               |  |  |  |  |

**Note** The INT pin can be used as an input pin (sensor input) when the external interrupt function is not used. The status of the pin is read with the INT flag of the control register, not with the port register.

Caution Although a PROM product is highly compatible with a masked ROM product in respect of functions, they differ in internal ROM circuits and part of electrical characteristics. Before changing the PROM product to the masked ROM product in an application system, evaluate the system carefully using the masked ROM product.

3



#### PIN CONFIGURATION (TOP VIEW)

## • 28-pin plastic shrink DIP (400 mil)

#### • 28-pin plastic SOP (375 mil)

 $\mu$ PD17145GT- $\times\times\times$ ,  $\mu$ PD17147GT- $\times\times\times$ ,  $\mu$ PD17149GT- $\times\times\times$ ,  $\mu$ PD17145GT(A)- $\times\times\times$ ,  $\mu$ PD17149GT(A)- $\times\times\times$ 



ADC<sub>0</sub> - ADC<sub>3</sub> : Analog input converter RESET : Reset input

 $P0D_0 - P0D_3$  : Port 0D VDD : Power supply

P0F<sub>0</sub> and P0F<sub>1</sub>: Port 0F X<sub>IN</sub>, X<sub>OUT</sub>: System clock oscillation



#### **BLOCK DIAGRAM**



Notes 1. The capacity of the ROM depends on the product, as follows.

 $1024 \times 16 \text{ bits: } \mu PD17145$   $2048 \times 16 \text{ bits: } \mu PD17147$   $4096 \times 16 \text{ bits: } \mu PD17149$ 

2. The capacity of the stack depends on the product, as follows.

5 × 10 bits:  $\mu$ PD17145 5 × 11 bits:  $\mu$ PD17147 5 × 12 bits:  $\mu$ PD17149

Remark The terms CMOS and N-ch in parentheses indicate the output form of the port.

CMOS: CMOS push-pull output
N-ch : N-channel open-drain output



# **CONTENTS**

| 1.  | PINS. |                                                                                                                                                                            | 9  |
|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
|     | 1.1   | PIN FUNCTIONS                                                                                                                                                              | ç  |
|     | 1.2   | EQUIVALENT INPUT/OUTPUT CIRCUITS                                                                                                                                           | 11 |
|     | 1.3   | HANDLING UNUSED PINS                                                                                                                                                       | 15 |
|     | 1.4   | NOTES ON USE OF THE RESET AND P0F0/RLS PINS                                                                                                                                | 16 |
| 2.  | PROG  | GRAM MEMORY (ROM)                                                                                                                                                          | 17 |
|     | 2.1   | PROGRAM MEMORY CONFIGURATION                                                                                                                                               | 17 |
| 3.  | PROG  | RAM COUNTER (PC)                                                                                                                                                           | 18 |
|     | 3.1   | PROGRAM COUNTER CONFIGURATION                                                                                                                                              | 18 |
|     | 3.2   | PROGRAM COUNTER OPERATION                                                                                                                                                  | 18 |
| 4.  | STAC  | Κ                                                                                                                                                                          | 19 |
|     | 4.1   | STACK CONFIGURATION                                                                                                                                                        | 19 |
|     | 4.2   | FUNCTIONS OF THE STACK                                                                                                                                                     | 19 |
| 5.  | DATA  |                                                                                                                                                                            | 20 |
|     | 5.1   | DATA MEMORY CONFIGURATION                                                                                                                                                  | 20 |
| 6.  | GENE  |                                                                                                                                                                            | 21 |
|     | 6.1   | GENERAL REGISTER POINTER (RP)                                                                                                                                              | 21 |
| 7.  | SYST  | ,                                                                                                                                                                          | 22 |
|     | 7.1   | SYSTEM REGISTER CONFIGURATION                                                                                                                                              | 22 |
| 8.  | REGI  | <b>`</b>                                                                                                                                                                   | 24 |
|     | 8.1   | REGISTER FILE CONFIGURATION                                                                                                                                                |    |
|     | 8.2   | FUNCTIONS OF THE REGISTER FILE                                                                                                                                             | 25 |
| 9.  | DATA  | BUFFER (DBF)                                                                                                                                                               |    |
|     | 9.1   | DATA BUFFER CONFIGURATION                                                                                                                                                  |    |
|     | 9.2   | FUNCTIONS OF THE DATA BUFFER                                                                                                                                               | 27 |
| 10. |       | BLOCK                                                                                                                                                                      | 28 |
|     | 10.1  | ALU BLOCK CONFIGURATION                                                                                                                                                    | 28 |
| 11. |       | 'S                                                                                                                                                                         | 30 |
|     | 11.1  | PORT 0A (P0A <sub>0</sub> , P0A <sub>1</sub> , P0A <sub>2</sub> , P0A <sub>3</sub> )                                                                                       | 30 |
|     | 11.2  | PORT 0B (P0B <sub>0</sub> , P0B <sub>1</sub> , P0B <sub>2</sub> , P0B <sub>3</sub> )                                                                                       | 31 |
|     | 11.3  | PORT 0C (P0C <sub>0</sub> / <u>ADC</u> <sub>0</sub> , P0C <sub>1</sub> /ADC <sub>1</sub> , P0C <sub>2</sub> /ADC <sub>2</sub> , <u>P0C<sub>3</sub>/AD</u> C <sub>3</sub> ) | 32 |
|     | 11.4  | PORT 0D (P0D <sub>0</sub> /SCK, P0D <sub>1</sub> /SO, P0D <sub>2</sub> /SI, P0D <sub>3</sub> /TM1OUT)                                                                      | 33 |
|     | 11.5  | PORT 0E (P0E <sub>0</sub> , P0E <sub>1</sub> , P0E <sub>2</sub> , P0E <sub>3</sub> )                                                                                       | 34 |
|     | 11.6  | PORT 0F (P0Fo/RLS, P0F1/VREF)                                                                                                                                              | 34 |



| 12. 8-BH   | TIMER COUNTER (TMU, TM1)                             |
|------------|------------------------------------------------------|
| 12.1       | CONFIGURATION OF 8-BIT TIMER COUNTERS                |
| 13 BASI    | C INTERVAL TIMER (BTM)                               |
| 13.1       | CONFIGURATION OF THE BASIC INTERVAL TIMER            |
| 13.1       | REGISTERS FOR CONTROLLING THE BASIC INTERVAL TIMER   |
|            |                                                      |
| 13.3       | WATCHDOG TIMER FUNCTION                              |
| 14. A/D (  | CONVERTER                                            |
| 14.1       | A/D CONVERTER CONFIGURATION                          |
| 14.2       | A/D CONVERTER FUNCTIONS                              |
| 14.3       | A/D CONVERTER OPERATION                              |
| 15. SERI   | AL INTERFACE (SIO)                                   |
| 15.1       | FUNCTIONS OF THE SERIAL INTERFACE                    |
| 15.2       | 3-WIRE SERIAL INTERFACE OPERATION MODES              |
| 13.2       | 3-WINE SERVE INTERVACE OF ERATION MODES              |
| 16. INTE   | RRUPT FUNCTIONS                                      |
| 16.1       | INTERRUPT SOURCE TYPES AND VECTOR ADDRESS            |
| 16.2       | HARDWARE COMPONENTS OF THE INTERRUPT CONTROL CIRCUIT |
| 17. STAN   | IDBY FUNCTION                                        |
| 17.1       | OVERVIEW OF THE STANDBY FUNCTION                     |
| 17.2       | HALT MODE                                            |
| 17.3       | STOP MODE                                            |
| 18 RESI    | T                                                    |
| 18.1       | RESET FUNCTIONS                                      |
| 18.2       | RESETTING                                            |
| 10.2       | RESETTING                                            |
| 19. POC    | CIRCUIT (MASK OPTION)                                |
| 19.1       | FUNCTIONS OF THE POC CIRCUIT                         |
| 19.2       | CONDITIONS UNDER WHICH THE POC CIRCUIT MAY BE USED   |
| 19.3       | CAUTIONS FOR USING THE POC CIRCUIT                   |
| 20. INST   | RUCTION SET                                          |
| 20.1       | OVERVIEW OF THE INSTRUCTION SET                      |
| 20.2       | LEGEND                                               |
| 20.3       | LIST OF THE INSTRUCTION SET                          |
| 20.4       | ASSEMBLER (AS17K) BUILT-IN MACRO INSTRUCTIONS        |
| 21 A C C I | EMBLER RESERVED WORDS                                |
|            |                                                      |
| 21.1       | MASK OPTION PSEUDO INSTRUCTIONS                      |
| 21.2       | RESERVED SYMBOLS                                     |
| 22. ELEC   | CTRICAL CHARACTERISTICS                              |



| 23. CHARACTE | ERISTIC CURVES (FOR REFERENCE)                                                          | 86 |
|--------------|-----------------------------------------------------------------------------------------|----|
| 24. PACKAGE  | DRAWINGS                                                                                | 88 |
| 25. RECOMME  | NDED SOLDERING CONDITIONS                                                               | 92 |
| APPENDIX A.  | DEVELOPMENT OF THE μPD171×× SUB-SERIES                                                  | 94 |
|              | COMPARISON OF FUNCTIONS OF $\mu$ PD17145 SUB-SERIES, $\mu$ PD17135A, AND $\mu$ PD17137A | 95 |
| APPENDIX C.  | DEVELOPMENT TOOLS                                                                       | 97 |



# 1. PINS

### 1.1 PIN FUNCTIONS

| Pin No. | Symbol                                                                     | Function                                                                                                                                       | Output          | After reset                  |
|---------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------|
| 1       | V <sub>DD</sub>                                                            | Power supply                                                                                                                                   | -               | -                            |
| 2       | P0F <sub>1</sub> /V <sub>REF</sub>                                         | Port 0F. The reference voltage is supplied to the A/D converter through this pin.                                                              | Input           | Input<br>(P0F <sub>1</sub> ) |
|         |                                                                            | Pull-up resistor incorporation specifiable by mask option                                                                                      |                 |                              |
|         |                                                                            | <ul> <li>P0F<sub>1</sub></li> <li>Bit 1 of 2-bit input port P0F</li> </ul>                                                                     |                 |                              |
|         |                                                                            | <ul> <li>V<sub>REF</sub></li> <li>Reference voltage input for the A/D converter</li> </ul>                                                     |                 |                              |
| 3 - 6   | P0C <sub>3</sub> /ADC <sub>3</sub> -<br>P0C <sub>0</sub> /ADC <sub>0</sub> | Port 0C. Analog voltage is supplied to the A/D converter through these pins.                                                                   | CMOS push-pull  | Input<br>(P0C)               |
|         |                                                                            | <ul> <li>P0C<sub>3</sub> - P0C<sub>0</sub></li> <li>4-bit input/output port</li> <li>Input/output setting allowed in units of 1 bit</li> </ul> |                 |                              |
|         |                                                                            | <ul> <li>ADC<sub>3</sub> - ADC<sub>0</sub></li> <li>Analog input for the A/D converter</li> </ul>                                              |                 |                              |
| 7       | P0B <sub>3</sub>                                                           | Port 0B                                                                                                                                        | CMOS push-pull  | Input                        |
| 8       | P0B <sub>2</sub>                                                           | 4-bit input/output port                                                                                                                        |                 |                              |
| 9       | P0B <sub>1</sub>                                                           | Input/output setting allowed in units of 4 bits                                                                                                |                 |                              |
| 10      | P0B <sub>0</sub>                                                           | <ul> <li>Pull-up resistor incorporation specifiable by program in<br/>units of 4 bits</li> </ul>                                               |                 |                              |
| 11      | Р0А3                                                                       | Port 0A                                                                                                                                        | CMOS push-pull  | Input                        |
| 12      | P0A <sub>2</sub>                                                           | 4-bit input/output port                                                                                                                        |                 |                              |
| 13      | P0A <sub>1</sub>                                                           | <ul> <li>Input/output setting allowed in units of 4 bits</li> </ul>                                                                            |                 |                              |
| 14      | P0A <sub>0</sub>                                                           | <ul> <li>Pull-up resistor incorporation specifiable by program in<br/>units of 4 bits</li> </ul>                                               |                 |                              |
| 15      | P0E <sub>3</sub>                                                           | Port 0E                                                                                                                                        | N-ch open drain | Input                        |
| 16      | P0E <sub>2</sub>                                                           | 4-bit input/output port                                                                                                                        | (withstand      |                              |
| 17      | P0E <sub>1</sub>                                                           | Input/output setting allowed in units of 4 bits                                                                                                | voltage: VDD    |                              |
| 18      | P0E₀                                                                       | <ul> <li>Pull-up resistor incorporation specifiable by program in units of 4 bits</li> </ul>                                                   | (max.))         |                              |

+



| Pin No.  | Symbol                | Function                                                                                                                                                                                                                                                                                                        | Output                                                   | After reset     |
|----------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-----------------|
| 19       | P0D₃/TM1OUT           | Pin for port 0D, timer 1 output, serial data input, serial data output, and serial clock input/output  • Pull-up resistor incorporation specified by program bit by bit  • P0D <sub>3</sub> - P0D <sub>0</sub> • 4-bit input/output port  • Input/output setting allowed bit by bit  • TM10UT  • Timer 1 output | N-ch open drain<br>(withstand<br>voltage: VDD<br>(max.)) | Input<br>(P0D)  |
| 20       | P0D <sub>2</sub> /SI  | SI     Serial data input                                                                                                                                                                                                                                                                                        |                                                          |                 |
| 21       | P0D <sub>1</sub> /SO  | SO     Serial data output                                                                                                                                                                                                                                                                                       |                                                          |                 |
| 22       | P0D <sub>0</sub> /SCK | SCK     Serial clock input/output                                                                                                                                                                                                                                                                               |                                                          |                 |
| 23       | P0F <sub>0</sub> /RLS | Pin for port 0F and input for standby mode release signal  • Pull-up resistor incorporation specifiable by mask option  • P0F0  • Bit 0 of 2-bit input port P0F  •RLS  • Input for standby mode release signal                                                                                                  | Input                                                    | Input<br>(P0F₀) |
| 24       | INT                   | Input for an external interrupt request signal and standby mode release signal.  • Pull-up resistor incorporation specifiable by mask option.                                                                                                                                                                   | Input                                                    | Input           |
| 25       | RESET                 | System reset input pin  Pull-up resistor incorporation specifiable by mask option                                                                                                                                                                                                                               | Input                                                    | Input           |
| 26<br>27 | Xout<br>Xin           | For system clock oscillation The ceramic resonator is connected between X <sub>IN</sub> and X <sub>OUT</sub> .                                                                                                                                                                                                  | -                                                        | -               |
| 28       | GND                   | Ground                                                                                                                                                                                                                                                                                                          | -                                                        | -               |



#### 1.2 EQUIVALENT INPUT/OUTPUT CIRCUITS

Below are simplified diagrams of the input/output circuits for each pin.

#### (1) P0A<sub>0</sub> - P0A<sub>3</sub>, P0B<sub>0</sub> - P0B<sub>3</sub>





#### (2) P0C<sub>0</sub>/ADC<sub>0</sub> - P0C<sub>3</sub>/ADC<sub>3</sub>



# (3) P0D<sub>3</sub>/TM1OUT, P0D<sub>1</sub>/SO





#### (4) P0D<sub>2</sub>/SI, P0D<sub>0</sub>/SCK



#### (5) P0E<sub>0</sub> - P0E<sub>3</sub>



# (6) P0F<sub>0</sub>/RLS





# (7) P0F<sub>1</sub>/V<sub>REF</sub>



# (8) RESET, INT





#### 1.3 HANDLING UNUSED PINS

The unused pins should be handled as described in Table 1-1.

**Table 1-1 Handling Unused Pins** 

|      |                                 | D:                             | Conditions                                                                           | and handling                                                             |                                                                                    |                                    |
|------|---------------------------------|--------------------------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------------|
|      |                                 | Pin                            | Internal                                                                             | External                                                                 |                                                                                    |                                    |
| Port | t Input P0A, P0B, P0D, mode P0E |                                | Pull-up resistors that can be specified with the software are incorporated.          | Leave open.                                                              |                                                                                    |                                    |
|      |                                 | POC                            | -                                                                                    | Connect to V <sub>DD</sub> or to ground through separate resistorsNote 1 |                                                                                    |                                    |
|      |                                 | P0F <sub>1</sub>               | Pull-up resistors that can be specified with the mask option are not incorporated.   | Connect directly to ground.                                              |                                                                                    |                                    |
|      |                                 |                                | Pull-up resistors that can be specified with the mask option are incorporated.       | Leave open.                                                              |                                                                                    |                                    |
|      |                                 | P0F <sub>0</sub> Note 2        | Pull-up resistors that can be specified with the mask option are not incorporated.   | Connect directly to ground.                                              |                                                                                    |                                    |
|      | Output<br>mode                  | P0A, P0B, P0C<br>(CMOS ports)  | -                                                                                    | Leave open.                                                              |                                                                                    |                                    |
|      |                                 | P0D (N-ch open-<br>drain port) | Outputs low level.                                                                   |                                                                          |                                                                                    |                                    |
|      |                                 | P0E (N-ch open-<br>drain port) | Outputs low level without pull-up resistors that can be specified with the software. |                                                                          |                                                                                    |                                    |
|      |                                 |                                | Outputs high level with pull-up resistors that can be specified with the software.   |                                                                          |                                                                                    |                                    |
| Ext  | External interrupt (INT)        |                                |                                                                                      |                                                                          | Pull-up resistors that can be specified with the mask option are not incorporated. | Connect directly to VDD or ground. |
|      |                                 |                                | Pull-up resistors that can be specified with the mask option are incorporated.       | Leave open.                                                              |                                                                                    |                                    |
| l    |                                 | nly internal POC               | Pull-up resistors that can be specified with the mask option are not incorporated.   | Connect directly to VDD.                                                 |                                                                                    |                                    |
|      |                                 |                                | Pull-up resistors that can be specified with the mask option are incorporated.       |                                                                          |                                                                                    |                                    |

★ Notes 1. When a pin is pulled up to VDD (connected to VDD through resistors) or pulled down to ground (connected to ground through resistors) outside the chip, take the driving capacity and maximum current consumption of a port into consideration. When using high-resistance pull-up or pull-down resistors, apply appropriate countermeasures to ensure that noise is not attracted by the resistors. Although the optimum pull-up or pull-down resistor varies with the application circuit, in general, a resistor of 10 to 100 kilohms is suitable.



- **Notes 2.** Since the P0F<sub>0</sub>/RLS pin is also used for setting the test mode, connect it directly to ground without incorporating a pull-up resistor that can be specified with the mask option, when the pin is not used.
  - 3. When designing an application circuit which requires high reliability, be sure to design a circuit to which an external RESET signal can be input. Since the RESET pin is also used for setting the test mode, connect it to Vpp directly when not used.

Caution To fix the I/O mode, pull-up resistors that can be specified with the software, and output level of a pin, it is recommended that they should be specified repeatedly within a loop in a program.

#### 1.4 NOTES ON USE OF THE RESET AND POFO/RLS PINS

The RESET and P0F<sub>0</sub>/RLS pins have the test mode selecting function for testing the internal operation of the  $\mu$ PD17149 (IC test), besides the functions shown in **Section 1.1**.

Applying a voltage exceeding V<sub>DD</sub> to the RESET and/or P0F<sub>0</sub>/RLS pin causes the µPD17149 to enter the test mode. When noise exceeding V<sub>DD</sub> comes in during normal operation, the device is switched to the test mode.

For example, if the wiring from the RESET or P0F<sub>0</sub>/RLS pin is too long, noise may be induced on the wiring, causing this mode switching.

When installing the wiring, lay the wiring in such a way that noise is suppressed as much as possible. If noise yet arises, use an external part to suppress it as shown below.

 Connect a diode with low V<sub>F</sub> between the pin and V<sub>DD</sub>.  $\bullet$  Connect a capacitor between the pin and  $V_{\text{DD}}.$ 







#### 2. PROGRAM MEMORY (ROM)

Table 2-1 lists the program memory configuration for the  $\mu$ PD17145,  $\mu$ PD17147, and  $\mu$ PD17149.

ProductProgram memory capacityAddress range $\mu$ PD171452K bytes<br/>(1024 × 16 bits)0000H - 03FFH $\mu$ PD171474K bytes<br/>(2048 × 16 bits)0000H - 07FFH $\mu$ PD171498K bytes0000H - 0FFFH

 $(4096 \times 16 \text{ bits})$ 

**Table 2-1 Program Memory Configuration** 

Program memory stores the program and the constant data table.

The program memory address is specified by the program counter.

The reset start address and interrupt vector addresses are assigned to program memory 0000H to 0005H.

#### 2.1 PROGRAM MEMORY CONFIGURATION

Fig. 2-1 shows the program memory map. A step consists of 16 bits of program memory. A 2K-step area is called a page.

Direct subroutine calls can specify address 0000H to 07FFH (page 0) in program memory. Branch instructions, indirect subroutine calls, and table references can specify any address in program memory (0000H - 0FFFH).



Fig. 2-1 Program Memory Map



#### 3. PROGRAM COUNTER (PC)

The program counter is used to specify an address in program memory.

#### 3.1 PROGRAM COUNTER CONFIGURATION

As shown in Fig. 3-1, the program counter is a 10/11/12-bit binary counter.

Fig. 3-1 Program Counter



#### 3.2 PROGRAM COUNTER OPERATION

Normally, the program counter is automatically incremented each time a command is executed. The memory address at which the next instruction to be executed is stored is assigned to the program counter under the following conditions: At reset; when a branch, subroutine call, return, or table referencing instruction is executed; or when an interrupt is received.

Fig. 3-2 Value of the Program Counter after an Instruction Is Executed

| Program counter                       |       | Program counter value                                                                |           |          |      |     |     |     |     |     |     |     |
|---------------------------------------|-------|--------------------------------------------------------------------------------------|-----------|----------|------|-----|-----|-----|-----|-----|-----|-----|
| Instruction                           | PC11  | PC10                                                                                 | PC9       | PC8      | PC7  | PC6 | PC5 | PC4 | PC3 | PC2 | PC1 | PC0 |
| During reset                          | 0     | 0                                                                                    | 0         | 0        | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| BR addr                               | 0     | Value                                                                                | set by    | addr     |      |     |     |     |     |     |     |     |
|                                       | 1     |                                                                                      |           |          |      |     |     |     |     |     |     |     |
| CALL addr                             | 0     |                                                                                      |           |          |      |     |     |     |     |     |     |     |
| BR @AR<br>CALL @AR<br>(MOVT DBF, @AR) | Value | Value in the address register (AR)                                                   |           |          |      |     |     |     |     |     |     |     |
| RET<br>RETSK<br>RETI                  |       | Value in the address stack location pointed to by the stack pointer (return address) |           |          |      |     |     |     |     |     |     |     |
| During interrupt                      | Vecto | r addre                                                                              | ss for th | ne inter | rupt |     |     |     |     |     |     |     |

**Remark** The  $\mu$ PD17145 does not have PC11 or PC10. The  $\mu$ PD17147 does not have PC11.



#### 4. STACK

The stack is a register used to save information such as the program return address and the contents of the system register during execution of subroutine calls, interrupts and similar operations.

#### 4.1 STACK CONFIGURATION

Fig. 4-1 shows the configuration of the stack.

The stack consists of the following parts: one 3-bit binary counter stack pointer (SP), five 10-bit ( $\mu$ PD17145)/11-bit ( $\mu$ PD17149) address stack registers (ASR), and three 5-bit interrupt stack registers (INTSK).



0H

1H

2H

BCDSK0

BCDSK1

BCDSK2

CMPSK0

CMPSK1

CMPSK2

CYSK0

CYSK1

CYSK2

ZSK0

ZSK1

7SK2

IXESK0

IXESK2

Fig. 4-1 Stack Configuration

#### 4.2 FUNCTIONS OF THE STACK

The stack is used to save the return address during execution of subroutine calls and table reference instructions. When an interrupt occurs, the program return address and the program status word (PSWORD) are automatically saved in the stack. Then, all bits of the PSWORD are cleared to 0.



#### 5. DATA MEMORY (RAM)

Data memory (RAM) stores data such as operation and control data. Data can be read from or written to data memory with an instruction during normal operation.

#### **5.1 DATA MEMORY CONFIGURATION**

Data memory locations have 7-bit addresses. The three high-order bits of each address are called the row address, and the four low-order bits are called the column address.

For example, the row address of address 1AH is 1H. The column address is 0AH.

Each addressed memory location is 4-bits (one nibble) long.

Data memory contains an area to which the user is allowed to store data freely, as well as areas which are reserved for the use of specific functions.

The areas reserved for specific functions are as follows:

System register (SYSREG) (See Chapter 7.)
 Data buffer (DBF) (See Chapter 9.)
 Port registers (See Chapter 11.)

Fig. 5-1 Organization of Data Memory





#### 6. GENERAL REGISTER (GR)

The general register, as the name implies, is a general register used for data transfer and manipulation. In the 17K series, the location of the general register is not fixed. The area used for the general register is in data memory, as specified by the general register pointer (RP). Thus, part of the data memory area can be specified as the general register as required, allowing data transfer in data memory and data memory manipulation to be performed with a single instruction.

#### 6.1 GENERAL REGISTER POINTER (RP)

RP is a pointer used to specify part of data memory as the general register. In RP, specify a desired data memory bank and row address for the general register. RP consists of seven bits: 7DH (RPH), and the three high-order bits of 7EH (RPL) in the system register (see **Chapter 7**).

Set a bank in RPH, and a data memory row address in RPL.



Fig. 6-1 General Register Pointer Configuration



#### 7. SYSTEM REGISTER (SYSREG)

The system register (SYSREG), located in data memory, is used for direct control of the CPU.

#### 7.1 SYSTEM REGISTER CONFIGURATION

Fig. 7-1 shows the allocation address of the system register in data memory. As shown in Fig. 7-1, the system register is allocated in addresses 74H to 7FH of data memory.

Since the system register is allocated in data memory, it can be manipulated using any of the instructions available for manipulating data memory. Therefore, it is also possible to put the system register in the general register.

Column address 3 5 В С D Ε F 0 1 2 Row address Data memory 3 (BANK0) 4 5 6 7 Port register System register (SYSREG) 0 3 4 5 6 7 8 С Ε F 9 В D

Fig. 7-1 Allocation of System Register in Data Memory

Fig. 7-2 shows the configuration of the system register. As shown in Fig. 7-2, the system register consists of the following seven registers.

Address register (AR)
Window register (WR)
Bank register (BANK)
Index register (IX)
Data memory row address pointer (MP)
General register pointer (RP)
Program status word (PSWORD)

Address 74H 7DH 7EH 75H 76H 77H 78H 79H 7AH 7BH 7CH 7FH Index register (IX) General Program Window Bank Address register register status Name register register Data memory (AR) pointer word row address pointer (MP) (WR) (BANK) (RP) (PSWORD IXH IXM RPL Symbol AR3 AR2 AR1 AR0 WR **BANK** IXL **RPH PSW** MPH MPL (IX) BCC M Note 2 Note 2 DataNote 1 0 0 0 0 P 0 0 0 0 0 0 0 0 |C|M|Y|Z|XDP Е (BANK) (MP) (RP) (AR) Initial value Not 00000000000000000000 when reset

Fig. 7-2 System Register Configuration

- Notes 1. A bit indicating zero is fixed to zero.
  - 2. Bit b<sub>3</sub> and b<sub>2</sub> of AR2 are always 0 for the  $\mu$ PD17145. Bit b<sub>3</sub> of AR2 is always 0 also for the  $\mu$ PD17147.



#### 8. REGISTER FILE (RF)

The register file is a register used mainly for specifying conditions for peripheral hardware.

#### 8.1 REGISTER FILE CONFIGURATION

#### 8.1.1 Configuration of the Register File

Fig. 8-1 shows the configuration of the register file.

As shown in Fig. 8-1, the register file is a register consisting of 128 nibbles (128  $\times$  4 bits).

In the same way as with data memory, the register file is divided into addresses in units of four bits. It has a total of 128 nibbles specified in row addresses from 0H to 7H and column addresses from 0H to 0FH.

Address locations 00H to 3FH define an area called the control register.

Fig. 8-1 Register File Configuration

#### 8.1.2 Relationship between the Register File and Data Memory

Fig. 8-2 shows the relationship between the register file and data memory.

As shown in Fig. 8-2, the register file overlaps with data memory at addresses 40H to 7FH.

This means that, on a program, it seems that the same memory exists in the register file at addresses 40H to 7FH and in the data memory at addresses 40H to 7FH.



Fig. 8-2 Relationship Between the Register File and Data Memory

#### 8.2 FUNCTIONS OF THE REGISTER FILE

#### 8.2.1 Functions of the Register File

The register file is a collection of registers in which peripheral hardware conditions are set with the PEEK instruction or POKE instruction.

The register used to control the peripheral hardware is located at addresses 00H to 3FH. This area is called the control register.

Addresses 40H to 7FH of the register file constitute normal data memory. Thus, not only the MOV instruction, but also the PEEK and POKE instructions, can be used to enable this part to perform read and write operations.

#### 8.2.2 Control Register Functions

The peripheral hardware whose conditions can be controlled by control registers is listed below.

For details concerning peripheral hardware and the control register, see the section for the peripheral hardware concerned.

- Ports
- 8-bit timer counter (TM0, TM1)
- · Basic interval timer (BTM)
- A/D converter
- Serial interface (SIO)
- · Interrupt function
- · Stack pointer (SP)



#### 9. DATA BUFFER (DBF)

The data buffer consists of four nibbles allocated in addresses 0CH to 0FH in BANKO.

The data buffer acts as a data storage area for the CPU peripheral hardware (address register, serial interface, timer 0, timer 1, and A/D converter) through use of the GET and PUT instructions. It also acts as data storage used for receiving and transferring data. By using the MOVT DBF, @AR instruction, fixed data in program memory can be read into the data buffer.

#### 9.1 DATA BUFFER CONFIGURATION

Fig. 9-1 shows the allocation of the data buffer in data memory.

As shown in Fig. 9-1, the data buffer is allocated in address locations 0CH to 0FH in data memory and consists of four nibbles  $(4 \times 4 \text{ bits})$ .



Fig. 9-1 Allocation of the Data Buffer

Fig. 9-2 shows the configuration of the data buffer. As shown in Fig. 9-2, the data buffer is made up of sixteen bits with its least significant bit in bit 0 of address 0FH and its most significant bit in bit 3 of address 0CH.

0FH Address 0CH 0DH 0FH Data memory BANK0 Bit рз  $b_2$ b<sub>1</sub>  $b_0$ bз b<sub>1</sub>  $b_0$ bз  $b_2$ b<sub>1</sub>  $b_0$ bз b<sub>1</sub>  $b_0$ Bit b<sub>10</sub> b<sub>9</sub> **b**15 b<sub>14</sub> b<sub>13</sub> **b**12 b<sub>11</sub> b<sub>7</sub> b<sub>5</sub> b<sub>4</sub> bз b<sub>1</sub>  $b_0$ b<sub>8</sub> b<sub>6</sub>  $b_2$ Data buffer Symbol DBF3 DBF2 DBF1 DBF0 ^L S B ^M S B Data Data ٧

Fig. 9-2 Data Buffer Configuration

Because the data buffer is allocated in data memory, it can be used in any of the data memory manipulation instructions.



#### 9.2 FUNCTIONS OF THE DATA BUFFER

The data buffer has two separate functions.

The data buffer is used for data transfer with peripheral hardware. The data buffer is also used for reading constant data in program memory. Fig. 9-3 shows the relationship between the data buffer and peripheral hardware.

Data buffer (DBF) Peripheral address Peripheral hardware Internal bus 01H Shift register (SIOSFR) Timer 0 modulo register 02H (TMOM) Timer 1 modulo register 03H (TM1M) Program memory (ROM) A/D converter data register (ADCR) 04H Constant data 40H Address register (AR) Timer 0/timer 1 count register (TM0TM1C) 45H

Fig. 9-3 Relationship between the Data Buffer and Peripheral Hardware



#### 10. ALU BLOCK

The ALU is used for performing arithmetic operations, logical operations, bit evaluations, comparison evaluations, and rotations on 4-bit data.

#### 10.1 ALU BLOCK CONFIGURATION

Fig. 10-1 shows the configuration of the ALU block.

As shown in Fig. 10-1, the ALU block consists of the main 4-bit data processor, temporary registers A and B, the status flip-flop for controlling the status of the ALU, and the decimal conversion circuit for use during arithmetic operations in BCD.

As shown in Fig. 10-1, the status flip-flop consists of the following flags: Zero flag flip-flop, carry flag flip-flop, compare flag flip-flop, and the BCD flag flip-flop.

Each flag in the status flip-flop corresponds directly to a flag in the program status word (PSWORD: addresses 7EH, 7FH) located in the system register. The flags in the program status word are the following: Zero flag (Z), carry flag (CY), compare flag (CMP), and the BCD flag (BCD).



Fig. 10-1 Configuration of the ALU







#### 11. PORTS

#### 11.1 PORT 0A (P0A<sub>0</sub>, P0A<sub>1</sub>, P0A<sub>2</sub>, P0A<sub>3</sub>)

Port 0A is a 4-bit input/output port with an output latch. It is mapped into address 70H of BANK0 in data memory. The output format is CMOS push-pull output.

Input or output can be specified in 4-bit units. Input/output is specified by P0AGIO (bit 0 at address 2CH) in the register file.

When P0AGIO is 0, each pin of port 0A is used as input port. If a read instruction is executed for the port register, pin statuses are read.

When P0AGIO is 1, each pin of port 0A is used as output port and the contents written in the output latch are output to pins. If a read instruction is executed when pins are output ports, the contents of the output latch, rather than pin statuses, are fetched.

Port 0A contains a software controlled pull-up resistor. P0AGPU (bit 0 at address 0CH) of the register file is used to determine whether port 0A contains the pull-up resistor. When P0AGPU is 1, all 4-bit pins are pulled up. If P0AGPU is 0, the pull-up resistor is not contained.

At reset, P0AGIO and P0AGPU are set to 0 and all P0A pins become input ports without a pull-up resistor. The contents of the port output latch are 0.

Table 11-1 Writing into and Reading from the Port Register (0.70H)

|   | P0AGIO         | Pin input/output    | BANKO 70H              |                   |  |  |
|---|----------------|---------------------|------------------------|-------------------|--|--|
|   | RF: 2CH, bit 0 | i iii iiipul/output | Write                  | Read              |  |  |
|   | 0              | Input               | Possible               | P0A pin status    |  |  |
| Ī | 1              | Output              | Write to the P0A latch | Data in P0A latch |  |  |



#### 11.2 PORT 0B (P0B<sub>0</sub>, P0B<sub>1</sub>, P0B<sub>2</sub>, P0B<sub>3</sub>)

Port 0B is a 4-bit input/output port with an output latch. It is mapped into address 71H of BANK0 in data memory. The output format is CMOS push-pull output.

Input or output can be specified in 4-bit units. Input/output is specified by P0BGIO (bit 1 at address 2CH) in the register file.

When P0BGIO is 0, all pins of port 0B are used as input ports. If a read instruction is executed for the port register, pin statuses are read.

When P0BGIO is 1, all pins of port 0B are used as output ports. The contents written in the output latch are output to pins. If a read instruction is executed when pins are used as output ports, the contents of the output latch, rather than pin statuses, are fetched.

Port 0B contains a software controlled pull-up resistor. P0BGPU (bit 1 at address 0CH) is used to determine whether or not port 0B contains a pull-up resistor. When P0BGPU is 1, all 4-bit pins are pulled up. When P0BGPU is 0, a pull-up resistor is not contained.

At reset, P0BGIO and P0BGPU are 0 and all P0B pins are input ports without a pull-up resistor. The value of the port 0B output latch is 0.

Table 11-2 Writing into and Reading from the Port Register (0.71H)

| P0BGIO         | Pin input/output    | BANK                   | 0 71H             |
|----------------|---------------------|------------------------|-------------------|
| RF: 2CH, bit 1 | 1 III IIIpat/output | Write                  | Read              |
| 0              | Input               | Possible               | P0B pin status    |
| 1              | Output              | Write to the P0B latch | Data in P0B latch |



#### 11.3 PORT 0C (P0C<sub>0</sub>/ADC<sub>0</sub>, P0C<sub>1</sub>/ADC<sub>1</sub>, P0C<sub>2</sub>/ADC<sub>2</sub>, P0C<sub>3</sub>/ADC<sub>3</sub>)

Port 0C is a 4-bit input/output port with an output latch. It is mapped into address 72H of BANK0 in data memory. The output format is CMOS push-pull output.

Input or output can be specified bit-by-bit. Input/output can be specified by P0CBIO0 to P0CBIO3 (address 1CH) in the register file.

If P0CBIOn is 0 (n = 0 to 3), the P0Cn pins are used as input port. If a data read instruction is executed for the port register, the pin statuses are read. If P0CBIOn is 1 (n = 0 to 3), the P0Cn pins are used as output port and the contents written in the output latch are output to pins. If a read instruction is executed when pins are used as output ports, the contents of the latch, rather than pin statuses, are fetched.

At reset, P0CBIO0 to P0CBIO3 are 0 and all P0C pins are input ports. The contents of the port output latch are 0.

Port 0C can also be used as an analog input to the A/D converter. P0C0IDI to P0C3IDI (1BH address) in the register file are used to switch the port and analog input pin.

If P0CnIDI is 0 (n = 0 to 3), the P0Cn/ADCn pin functions as a port. If P0CnIDI is 1 (n = 0 to 3), the P0Cn/ADCn pin functions as the analog input pin for the A/D converter. If any bit of P0CnIDI (n = 0 to 3) is 1, the P0F<sub>1</sub>/V<sub>REF</sub> pin is used as the V<sub>REF</sub> pin.

When using these pins for the analog input for the A/D converter, set P0CnIDI to 1 for the pins to which analog voltage is input, immediately after reset. This setting disables the port function for the pins. Then clear P0CBIOn (n = 0 to 3) to 0 to use the pins for input. Select which pins are used for analog input, using ADCCH0 and ADCCH1 (bits 0 and 1 at address 22H) in the register file.

At reset, P0CBIO0 to P0CBIO3, P0C0IDI to P0C3IDI, ADCCH0, and ADCCH1 are set to 0 and the P0C pins are used as input ports.

|         |         |                                                   |                       | (11 = 0 to 3)     |  |  |
|---------|---------|---------------------------------------------------|-----------------------|-------------------|--|--|
| P0CnIDI | P0CBIOn | Function                                          | BANK0 72H             |                   |  |  |
| RF: 1BH | RF: 1CH |                                                   | Write                 | Read              |  |  |
| 0       | 0       | Input port                                        | Possible<br>P0C latch | Pin status        |  |  |
|         | 1       | Output port                                       | Possible<br>P0C latch | Data in P0C latch |  |  |
| 1       | 0       | A/D converter analog inputNote 1                  | Possible<br>P0C latch | Data in P0C latch |  |  |
|         | 1       | Output port and A/D converter analog input Note 2 | Possible<br>P0C latch | Data in P0C latch |  |  |

Table 11-3 Switching the Port and A/D Converter

(n = 0 to 3)

Notes 1. Normal setting when the pins are used as A/D converter analog input pins.

**2.** Functions as an output port. The analog input voltage is changed by the output from the port. To use the pins for analog input, be sure to set POCBIOn to 0.



#### 11.4 PORT 0D (P0D<sub>0</sub>/SCK, P0D<sub>1</sub>/SO, P0D<sub>2</sub>/SI, P0D<sub>3</sub>/TM1OUT)

Port 0D is a 4-bit input/output port with an output latch. It is mapped into address 73H of BANK0 in data memory. The output format is N-ch open-drain output.

Input or output can be specified bit-by-bit. Input/output is specified with P0DBIO0 to P0DBIO3 (address 2BH) in the register file.

If P0DBIOn is 0 (n = 0 to 3), the P0Dn pins are used as input port. Pin statuses are read if a data read instruction is executed for the port register. If P0DBIOn is 1, the P0Dn pins are used as output port and the value written in the output latch are output to pins. If a data read instruction is executed when pins are used as output ports, the output latch value, rather than pin statuses, is fetched.

Port 0D contains a software controlled pull-up resistor. P0DBPU0 to P0DBPU3 (address 0DH) of the register file are used to determine whether each bit of port 0D contains the pull-up resistor. When P0DBPUn is 1, the P0Dn pin is pulled up. If P0DBPUn is 0, the pull-up resistor is not contained.

At reset, P0DBIOn is set to 0 and all P0D pins become input ports. The contents of the port output latch become 0. The output latch contents remain unchanged even if P0DBIOn changes from 1 to 0.

Port 0D can also be used for serial interface input/output or timer 1 output. SIOEN (0BH bit 0) in the register file is used to switch ports ( $P0D_0$  to  $P0D_2$ ) to serial interface input/output ( $\overline{SCK}$ , SO, SI) and vice versa. TM1OSEL (bit 3 at address 0BH) in the register file is used to switch a port ( $P0D_3$ ) to timer 1 output ( $\overline{TM1OUT}$ ) and vice versa. If TM1OSEL = 1 is selected, 1 is output at timer 1 reset. This output is inverted every time a timer 1 count value matches the modulo register contents.

Table 11-4 Register File Contents and Pin Functions

(n = 0 to 3)

| Register file value         |                           |                             | Pin function         |                      |                      |                          |
|-----------------------------|---------------------------|-----------------------------|----------------------|----------------------|----------------------|--------------------------|
| TM1OSEL<br>RF: 0BH<br>Bit 3 | SIOEN<br>RF: 0BH<br>Bit 0 | P0DBIOn<br>RF: 2BH<br>Bit n | P0D₀/ <del>SCK</del> | P0D <sub>1</sub> /SO | P0D <sub>2</sub> /SI | P0D <sub>3</sub> /TM1OUT |
| 0                           | 0                         | 0                           | Input port           |                      |                      |                          |
|                             |                           | 1                           | Output port          |                      |                      |                          |
|                             | 1                         | 0                           | SCK                  | SO                   | SI                   | Input port               |
|                             |                           | 1                           |                      |                      |                      | Output port              |
| 1                           | 0                         | 0                           | Input port           |                      |                      | TM1OUT                   |
|                             |                           | 1                           | Output port          |                      |                      |                          |
|                             | 1                         | 0                           | SCK                  | SO                   | SI                   |                          |
|                             |                           | 1                           |                      |                      |                      |                          |

|             | Port mode                                        | Data read from the port register (0.73H) |  |
|-------------|--------------------------------------------------|------------------------------------------|--|
| Input port  |                                                  | Pin status                               |  |
| Output port |                                                  | Data in output latch                     |  |
| 0014        | An internal clock is selected as a serial clock. | Data in output latch                     |  |
| SCK         | An external clock is selected as a serial clock. | Pin status                               |  |
| SI          |                                                  | Pin status                               |  |
| so          |                                                  | Data in output latch                     |  |
| TM1OUT      |                                                  | Data in output latch                     |  |

Table 11-5 Data Read from the Port Register (0.73H)

#### 11.5 PORT 0E (P0E<sub>0</sub>, P0E<sub>1</sub>, P0E<sub>2</sub>, P0E<sub>3</sub>)

Port 0E is a 4-bit input/output port with an output latch. It is mapped into address 6EH of BANK0 in data memory. The output format is N-ch open-drain output.

Input or output can be specified in units of four bits. Input/output is specified by P0EGIO (bit 2 at address 2CH) in the register file.

When P0EGIO is 0, each pin of port 0E is used as input port. If a read instruction is executed for the port register, pin statuses are read. When P0EGIO is 1, each pin of port 0E is used as output port and the contents written in the output latch are output to pins. If a read instruction is executed when pins are output ports, the contents of the output latch, rather than pin statuses, are fetched.

Port 0E contains a software controlled pull-up resistor. P0EGPU (bit 2 at address 0CH) of the register file in used to determine whether port 0E contains the pull-up resistor. When P0EGPU is 1, all 4-bit pins are pulled up. If P0EGPU is 0, the pull-up resistor is not contained.

At reset, P0EGIO is set to 0 and all P0E pins become input ports. The contents of the port output latch are 0.

Table 11-6 Writing into and Reading from the Port Register (0.6EH)

(n = 0 to 3)

| P0EGIOn        | Pin input/output    | BANKO 6EH              |                   |  |
|----------------|---------------------|------------------------|-------------------|--|
| RF: 2CH, bit 2 | i iii iiipai/oatpat | Write                  | Read              |  |
| 0              | Input               | Possible               | P0E pin status    |  |
| 1              | Output              | Write to the P0E latch | Data in P0E latch |  |

#### 11.6 PORT OF (P0F<sub>0</sub>/RLS, P0F<sub>1</sub>/V<sub>REF</sub>)

Port 0F is a 2-bit input-dedicated port. It is mapped into address 6FH of BANK0 in data memory. Mask option can be used to specify whether each pin uses a built-in pull-up resistor.

If a pin of port 0F is used as an input port, a pin status is read in the two low-order bits of the port register when a data read instruction is executed for the port register (the two high-order bits are always 0). A data write instruction does not affect the port register.

The P0F<sub>0</sub>/RLS pin can also be used for the input pin for the signal for releasing the standby mode.

The P0F<sub>1</sub>/V<sub>REF</sub> pin is used as the V<sub>REF</sub> pin (reference voltage input pin for the A/D converter) when any bit of P0CnIDI (address 1BH in the register file, n = 0 to 3) is 1. If the P0F<sub>1</sub>/V<sub>REF</sub> pin functions as the V<sub>REF</sub> pin, bit 1 at address 6FH is always 0 when a data read instruction is executed for the port register.



#### 12. 8-BIT TIMER COUNTER (TM0, TM1)

Timer 0 (TM0) and timer 1 (TM1) are available as 8 bit-timer counters of the  $\mu$ PD17149. By using the timer 0 counting signal as the timer 1 count clock, these two 8-bit counters can be used as one 16-bit timer.

The timers are controlled by hardware operation with the PUT/GET instruction or by register operation in the register file with the PEEK/POKE instruction.

#### 12.1 CONFIGURATION OF 8-BIT TIMER COUNTERS

Fig. 12-1 shows the configuration of the 8-bit timer counters. An 8-bit timer counter consists of an 8-bit counter register, 8-bit modulo register, comparator (compares counter register values and modulo register values), and selector (for count pulse selection).

Cautions 1. The modulo register is a write-only register.

2. The count register is a read-only register.



Fig. 12-1 Configuration of the 8-Bit Timer Counters







Fig. 12-2 Timer 0 Mode Register



**Remark** TM0EN can be used as a status flag for detecting the counting status of timer 0.

(1: Counting, 0: Not counting)



Fig. 12-3 Timer 1 Mode Register



Remark TM1EN can be used as a status flag for detecting the counting status of timer 1.

(1: Counting, 0: Not counting)



## 13. BASIC INTERVAL TIMER (BTM)

The  $\mu$ PD17149 provides a 7-bit basic interval timer. This timer has the following functions:

- (1) Reference time generation
- (2) Selection and counting of a wait time when standby mode is released
- (3) Watchdog timer operation for detecting software errors (infinite loops, etc.)

## 13.1 CONFIGURATION OF THE BASIC INTERVAL TIMER

Fig. 13-1 shows the configuration of the basic interval timer.

Fig. 13-1 Configuration of the Basic Interval Timer



Remark 1) to 4) in the figure indicate the signals in the timing chart in Fig. 13-4.



### 13.2 REGISTERS FOR CONTROLLING THE BASIC INTERVAL TIMER

The basic interval timer is controlled by the BTM mode register and watchdog timer mode register.

Fig. 13-2 and 13-3 show the configurations of the registers.

Fig. 13-2 BTM Mode Register





RF: 03H Bit 3 Bit 2 Bit 1 Bit 0 **WDTRES** WDTEN 0 0 Read/write Read = R, write = W R/W Initial value when reset 0 0 Controls wheter to enable the watchdog timer WDTEN function. 0 Puts the watchdog timer in stop status. Starts watchdog timer operation. Remarks 1. WDTEN cannot be cleared to 0 by the 2. WDTEN is automatically cleared to 0 after it is set to 1. 0 is always read. WDTRES Controls wheter to reset the watchdog timer. 0 Does not affect the watchdog timer. Resets the flip-flop used to retain a BTM overflow carry used for the watchdog timer.

Fig. 13-3 Watchdog Timer Mode Register

**Remark** WDTRES is automatically cleared to 0 after it is set to 1. 0 is always read.



### 13.3 WATCHDOG TIMER FUNCTION

The basic interval timer can also be used as a watchdog timer which detects a system hang.

### 13.3.1 Overview of the Watchdog Timer

The watchdog timer is a counter that generates a reset signal at constant intervals. When the generation of a reset signal is being disabled every time by the program, this function enables the system to be reset (starting from address 0000H) when the system hangs up (the watchdog timer is not reset within the expected time) for some reason, such as due to external noise.

Even if a program branches to an unexpected routine due to external noise and enters an infinite loop, the system can be recovered within a certain time by the reset signal that is generated by the watchdog timer.

## 13.3.2 Operation of the Watchdog Timer

If 1 is written in the WDTEN flag, the 1-bit scaler starts operating, causing the basic interval timer to operate as an 8-bit watchdog timer.

Once the watchdog timer runs, the watchdog timer function can be stopped only when the device is reset and WDTEN is cleared to 0.

- A reset by the watchdog timer can be disabled in the following two ways:
  - (1) Repeating WDTRES setting in the program
  - (2) Repeating BTMRES setting in the program

For (1), it is necessary to set WDTRES while the watchdog timer count is between 8 and 191 (immediately before 192), as shown in Fig. 13-4. Therefore, the program must be written so that SET1 WDTRES is executed at least once in a shorter period than that required for the watchdog timer count to reach 184.

For (2), it is necessary to set BTMRES before the basic interval timer (BTM) counts to reach 128. Therefore, the program must be written so that SET1 BTMRES is executed at least once in a shorter period than that required for the basic interval timer count to reach 128. However, using this method, interrupt handling by the basic interval timer is disabled.

Caution Setting WDTEN does not reset the basic interval timer. So, set BTMRES before setting WDTEN, to reset the basic interval timer.

### Example

SET1 : BTMRES
SET2 WDTEN, WDTRES
:



Fig. 13-4 Timing Chart for the Watchdog Timer (When the WDTRES Flag is Used)



## 14. A/D CONVERTER

 $\mu$ PD17149 contains an 8-bit resolution A/D converter with 4-channel analog input (P0C<sub>0</sub>/ADC<sub>0</sub> - P0C<sub>3</sub>/ADC<sub>3</sub>). The A/D converter uses the successive approximation method. The following two operation modes are available:

- (1) Continuous mode: 8-bit A/D conversion occurs starting at high-order bits.
- 2 Single mode: Comparison occurs with an arbitrary voltage value set in the 8-bit data register.

# 14.1 A/D CONVERTER CONFIGURATION

Fig. 14-1 shows the A/D converter configuration.

Fig. 14-1 Block Diagram for the A/D Converter



Note The 8-bit data register (ADCR) is cleared to 00H at the execution of STOP instruction.



### 14.2 A/D CONVERTER FUNCTIONS

## (1) ADC<sub>0</sub> - ADC<sub>3</sub> pins

These pins are used to input 4-channel analog voltage to the A/D converter. The A/D converter contains a sample hold circuit. Analog input voltage is internally retained during A/D conversion.

### (2) VREF pin

This pin is used to input the reference voltage for the A/D converter.

A signal input to  $ADC_0$  to  $ADC_3$  is converted to a digital signal based on voltage applied across  $V_{REF}$  and GND. To reduce the current consumption of the microcontroller, the A/D converter has a function for automatically stopping the current which flows into the  $V_{REF}$  pin when the converter is not operating. Current flows into the  $V_{REF}$  pin in the following cases.

## (1) Continuous mode (ADCSOFT = 0)

From when the ADCSTRT flag is set (1) until the ADCEND flag is set (1).

## Single mode (ADCSOFT = 1)

From when the ADCSTRT flag is set (1) or from when a value of the 8-bit data register is written until the result of comparison by the comparator is written in the ADCCMP flag.

- Remarks 1. When the HALT instruction is executed during the A/D conversion, the A/D converter operates until the ADCEND flag is set in continuous mode or until the result of comparison is saved in the ADCCMP flag in single mode. A current flows into the VREF pin while the A/D converter is operating.
  - 2. The A/D conversion stops when the STOP instruction is executed. The A/D converter is initialized and a current does not flow into the VREF pin. The A/D converter remains stopped after the STOP mode is released.

## (3) 8-bit data register (ADCR)

In the continuous mode, this 8-bit data register stores A/D conversion results for successive approximation. It is read by the GET instruction. In the single mode, the data in this register is converted to analog voltage by the internal D/A converter and the comparator compares this voltage with an analog signal input from the ADCn pin. A value can be written in this register by using the PUT instruction.

### (4) Comparator

The comparator compares an analog input voltage with voltage output from the D/A converter. Value 1 is output if analog input voltage is higher. Value 0 is output if this voltage is lower. The comparison result is stored in the 8-bit data register (ADCR) in the continuous mode. It is stored in the ADCCMP flag in the single mode.



## 14.3 A/D CONVERTER OPERATION

The A/D converter operates in two modes: continuous mode and single mode. The mode can be switched by setting the ADCSOFT flag.

| ADCSOFT | A/D converter operation mode     |
|---------|----------------------------------|
| 0       | Continuous mode (A/D conversion) |
| 1       | Single mode (comparison)         |

Fig. 14-2 Relation between the Analog Input Voltage and Digital Conversion Result





★ (1) Timing in the continuous mode operation (A/D conversion)



Fig. 14-3 Timing in the Continuous Mode Operation (A/D Conversion)

Caution Sampling is performed eight times for each A/D conversion. If the analog input voltage changes considerably during A/D conversion, accurate A/D conversion cannot be performed. To obtain accurate conversion, minimize any change in the analog input voltage during A/D conversion.

**Remark** Time required for one sampling operation = 14/fx (1.75  $\mu$ s, at fx = 8 MHz) Sampling cycle period = 48/fx (6  $\mu$ s, at fx = 8 MHz)



## ★ (2) Timing in the single mode operation (comparison)

Fig. 14-4 Timing in the Single Mode Operation (Comparison)



After data is set in ADCR (using the PUT instruction), the comparison result can be read after three instruction cycles.

Caution Before setting a value in ADCR, always set ADCSOFT to 1.

If ADCSOFT = 0, no value can be set in ADCR.

The PUT ADCR, DBF instruction is ineffective.

**Remark** Time required for sampling operation = 14/fx (1.75  $\mu$ s, at fx = 8 MHz)



## 15. SERIAL INTERFACE (SIO)

The serial interface of the  $\mu$ PD17149 consists of an 8-bit shift register (SIOSFR), serial mode register, and serial clock counter. It is used for serial data input/output.

### 15.1 FUNCTIONS OF THE SERIAL INTERFACE

This serial interface provides three signal lines: serial clock input pin  $(\overline{SCK})$ , serial data output pin (SO), and serial data input pin (SI). It allows 8 bits to be sent or received in synchronization with clocks. It can be connected to peripheral input/output devices using any method with a mode compatible to that used by the  $\mu$ PD7500 or 75X series.

### (1) Serial clock

Three types of internal clocks and one type of external clock are able to be selected. If an internal clock is selected as a serial clock, it is automatically output to the P0D<sub>0</sub>/SCK pin.

 $\star$ 

Table 15-1 Serial Clock

| SIOCK1 | SIOCK0 | Serial clock to be selected         |
|--------|--------|-------------------------------------|
| 0      | 0      | External clock input to the SCK pin |
| 0      | 1      | fx/16                               |
| 1      | 0      | fx/128                              |
| 1      | 1      | fx/1024                             |

### (2) Transmission operation

When SIOEN is set to 1, the pins of port 0D (P0D<sub>0</sub>/SCK, P0D<sub>1</sub>/SO, P0D<sub>2</sub>/SI) function as the pins of the serial interface. The serial interface operates in synchronization with the falling edge of the external or internal clock by setting SIOTS to 1. When SIOTS is set, IRQSIO is automatically cleared.

Transmission starts from the most significant bit of the shift register in synchronization with the falling edge of the serial clock. SI pin information is stored in the shift register starting at the least significant bit in synchronization with the rising edge of the clock.

When the 8-bits data transmission is terminated, SIOTS is automatically cleared and IRQSIO is set.

**Remark** Serial transmission starts only from the most significant bit of the shift register contents. It is not possible to transmit from the least significant bit. SI pin status is always stored in the shift register in synchronization with the rising edge of the serial clock.





Fig. 15-1 Block Diagram of the Serial Interface

Caution The output latch of the shift register is independent of that of the P0D<sub>1</sub> pin. Therefore, even if an output instruction is executed for the P0D<sub>1</sub> pin, the output latch status of the shift register does not change. Inputting a RESET signal clears the output latch of the shift register to 0. After that, the latch retains the LSB of the data transmitted previously.



### 15.2 3-WIRE SERIAL INTERFACE OPERATION MODES

Two modes can be used for the serial interface. If the serial interface function is selected, the P0D<sub>2</sub>/SI pin always takes in data in synchronization with the serial clock.

- 8-bit transmission and reception mode (simultaneous transmission and reception)
- 8-bit reception mode (with the SO pin output set to high impedance)

Table 15-2 Serial Interface Operation Mode

| SIOEN | SIOHIZ | P0Do/SI pin            | P0D1/SO pin  | Serial interface operation mode       |
|-------|--------|------------------------|--------------|---------------------------------------|
| 1     | 0      | SI                     | so           | 8-bit transmission and reception mode |
| 1     | 1      | SI                     | P0D1 (input) | 8-bit reception mode                  |
| 0     | ×      | P0D <sub>0</sub> (I/O) | P0D1 (I/O)   | General port mode                     |

X: Don't care

# (1) 8-bit transmission and reception mode (simultaneous transmission and reception)

Serial data input/output is controlled by a serial clock. The most significant bit of the shift register is output from the SO line with a falling edge of the serial clock (SCK). The contents of the shift register is shifted one bit and at the same time, data on the SI line is loaded into the least significant bit of the shift register.

The serial clock counter (3-bit counter) counts serial clock pulses. Every time it counts eight clocks, the internal interrupt request flag (IRQSIO) is set to 1.

Fig. 15-2 Timing of 8-Bit Transmission and Reception Mode (Simultaneous Transmission and Reception)



Remark DI: Input serial data

DO: Output serial data



## (2) 8-bit transmission and reception mode (with the SO pin set to the high impedance status)

When SIOHIZ is 1, the P0D<sub>1</sub>/SO pin is in the output high impedance status. If serial clock supply starts by writing 1 in SIOTS, only the reception function of the serial interface operates.

The P0D<sub>1</sub>/SO pin is in the high impedance status and can be used for input port (P0D<sub>1</sub>).



Fig. 15-3 Clock Synchronization 8-Bit Reception Mode

Remark DI: Input serial data

# (3) Operation stop mode

If the value in SIOTS (RF: address 02H, bit 3) is 0, the serial interface enters operation stop mode. In this mode, no serial transfer occurs.

In this mode, the shift register does not perform shifting and can be used as an ordinary 8-bit register.



### 16. INTERRUPT FUNCTIONS

The  $\mu$ PD17149 has five interrupt sources: four internal interrupt functions and one external interrupt function. It can be used in various applications.

The interrupt control circuit of the  $\mu$ PD17149 has the features listed below. This circuit enables very high-speed interrupt handling.

- (a) Used to determine whether an interrupt can be accepted with the interrupt mask enable flag (INTE) and interrupt enable flag (IPxxx).
- (b) The interrupt request flag (IRQ×××) can be tested or cleared. (Interrupt generation can be checked by software.)
- (c) Multiple interrupts are possible (up to three levels).
- (d) Standby mode (STOP, HALT) can be released by an interrupt request. (Release conditions can be selected by the interrupt enable flag.)

Caution In interrupt handling, only the BCD, CMP, CY, Z, and IXE flags are saved in the stack automatically by the hardware for up to three levels of multiple interrupts. The DBF and WR are not saved by the hardware when peripheral hardware such as the timers or A/D converter is accessed in interrupt handling. It is recommended that the DBF and WR be saved in RAM by the software at the beginning of interrupt handling. Saved data can be loaded back into the DBF and WR immediately before the end of interrupt handling.

### 16.1 INTERRUPT SOURCE TYPES AND VECTOR ADDRESS

For every interrupt in the  $\mu$ PD17149, when the interrupt is accepted, a branch occurs to the vector address associated with the interrupt source. This method is called the vectored interrupt method. Table 16-1 lists the interrupt source types and vector addresses.

If two or more interrupt requests occur or multiple suspended interrupt requests are enabled at the same time, they are handled according to priorities shown in Table 16-1.

Vector Internal/ IRQ flag Priority IP flag IEG flag Remarks Interrupt source address external 0005H IRQ 1 IΡ IEGMD0.1 External Rising edge or falling edge INT pin (RF: 0FH, bit 0) RF: 3FH. RF: 2FH, RF: 1FH can be selected. bit 0 bit 0 0004H IRQTM0 2 IPTM0 Internal Timer 0 RF: 3EH, RF: 2FH, bit 0 bit 1 0003H IRQTM1 IPTM1 Timer 1 Internal RF: 3DH. RF: 2FH, bit 0 bit 2 **IRQBTM** Basic interval timer 0002H **IPBTM** Internal RF: 3CH. RF: 2FH, bit 0 bit 3 **IRQSIO** Serial interface 5 0001H **IPSIO** Internal RF: 3BH, RF: 2EH. bit 0 bit 0

**Table 16-1 Interrupt Source Types** 



### 16.2 HARDWARE COMPONENTS OF THE INTERRUPT CONTROL CIRCUIT

The flags of the interrupt control circuit are explained below.

# (1) Interrupt request flag and the interrupt enable flag

The interrupt request flag (IRQ×××) is set to 1 when an interrupt request occurs. When interrupt handling is executed, the flag is automatically cleared to 0.

An interrupt enable flag (IPxxx) is provided for each interrupt request flag. If the flag is 1, an interrupt is enabled. If it is 0, the interrupt is disabled.

## (2) EI/DI instruction

The EI/DI instruction is used to determine whether an accepted interrupt is to be executed.

If the EI instruction is executed, the interrupt enable flag (INTE) for enabling interrupt reception is set. Since the INTE flag is not registered in the register file, flag status cannot be checked by instructions.

The DI instruction clears the INTE flag to 0 and disables all interrupts.

At reset the INTE flag is cleared to 0 and all interrupts are disabled.

Table 16-2 Interrupt Request Flag and Interrupt Enable Flag

| Interrupt request flag | Signal for setting the interrupt request flag                                                       | Interrupt<br>enable flag |
|------------------------|-----------------------------------------------------------------------------------------------------|--------------------------|
| IRQ                    | Set by edge detection of an INT pin input signal. A detection edge is selected by IEGMD0 or IEGMD1. | IP                       |
| IRQTM0                 | Set by a match signal from timer 0.                                                                 | IPTM0                    |
| IRQTM1                 | Set by a match signal from timer 1.                                                                 | IPTM1                    |
| IRQBTM                 | Set by an overflow (reference time interval signal) from the basic interval timer.                  | IPBTM                    |
| IRQSIO                 | Set by a serial data transmission end signal from the serial interface.                             | IPSIO                    |



### 17. STANDBY FUNCTION

### 17.1 OVERVIEW OF THE STANDBY FUNCTION

The  $\mu$ PD17149 can reduce its current by using the standby function. The standby function supports STOP and HALT modes.

In the STOP mode, the system clock is stopped and the CPU current is reduced to almost only a leak current. This mode is useful in retaining data memory contents without operating the CPU.

In the HALT mode, the oscillation of the system clock continues. However, the system clock is not supplied to the CPU, stopping CPU operation. In this mode, current reduction is less than that in the STOP mode. However, since the system clock is oscillating, operation can be started immediately after the HALT mode is released. In both STOP and HALT modes, the statuses of the data memory, registers, and output latches of the output port used immediately before the standby mode is set are maintained (except STOP 0000B). Therefore, in order to lower consumption current for the entire system, input/output port statuses should be set beforehand.

STOP mode HALT mode Programmed instruction STOP instruction HALT instruction Clock oscillator Oscillation stopped Oscillation continued CPU Operation stopped • The contents held immediately before setting standby mode are retained. **RAM**  The status existing immediately before setting standby mode is retained. Note Port TM0 · Operable only when the INT input is Operable selected as the count clock. Stopped when the system clock is selected. (The count is retained.) Opera-TM1 · Operation stopped. Operable tion (The count is reset to 0.) status (Count-up is also inhibited.) BTM · Operation stopped. Operable (The count is retained.) SIO · Operable only when the external clock is Operable selected as the shift clock. Note A/D Operation stopped<sup>Note</sup> (ADCR ← 00H) Operable INT Operable Operable

Table 17-1 Standby Mode Status

**Note** When STOP 0000B is executed, all pins are set to input port mode even if the pins are used in dual-function mode.

Cautions 1. Always specify a NOP instruction immediately before STOP and HALT instructions.

When an interrupt request flag and the corresponding interrupt enable flag are both set, and the associated interrupt is specified as the standby mode release condition, the system does not enter the standby mode even if a STOP or HALT instruction is executed.



### 17.2 HALT MODE

# 17.2.1 Setting HALT Mode

Executing a HALT instruction sets HALT mode.

Operand b3b2b1b0 of the HALT instruction indicates the HALT mode release conditions.

Table 17-2 HALT Mode Release Conditions

Format: HALT b3b2b1b0B

| Bit            | HALT mode release conditionsNote 1                                   |
|----------------|----------------------------------------------------------------------|
| bз             | When this bit is 1, release by IRQxxx is permitted. Notes 2, 4       |
| b <sub>2</sub> | Always 0                                                             |
| b <sub>1</sub> | When this bit is 1, forced release by IRQTM1 is permitted.Notes 3, 4 |
| b <sub>0</sub> | When this bit is 1, release by RLS input is permitted.Note 4         |

Notes 1. When HALT 0000B is specified, HALT mode can be released only by reset (RESET input or POC).

- **2.**  $IP \times \times \times$  must be 1.
- 3. HALT mode is released regardless of the IPTM1 status.
- **4.** If a HALT instruction is executed when IRQxxx = 1 or when the RLS input is low, the HALT instruction is ignored (treated as a NOP instruction), and HALT mode is not set.

## 17.2.2 Starting Address After HALT Mode is Released

The starting address depends on the release conditions and interrupt enable conditions.

Table 17-3 Starting Address After HALT Mode is Released

| Release<br>condition | Starting address after release                                                                                |
|----------------------|---------------------------------------------------------------------------------------------------------------|
| ResetNote 1          | Address 0                                                                                                     |
| RLS                  | Address subsequent to the HALT instruction                                                                    |
| IRQ×××Note 2         | For DI, address subsequent to the HALT instruction                                                            |
|                      | For EI, interrupt vector (When more than one IRQxxx is set, the interrupt vector having the highest priority) |

- Notes 1. RESET input and POC are valid.
  - 2. Except when forced release is made with IRQTM1, IPxxx must be 1.



Fig. 17-1 Releasing HALT Mode

# (a) Releasing HALT mode by RESET input



WAIT : Wait time until TM1 counts 256 source clock pulses (system clock/128)  $256 \times 128 \text{/fx}$  (approx. 4 ms at fx = 8 MHz)

# (b) Releasing HALT mode by RLS



# (c) Releasing HALT mode by IRQxxx (for DI)



# (d) Releasing HALT mode by IRQ××× (for EI)





### 17.3 STOP MODE

# 17.3.1 Setting STOP Mode

Executing a STOP instruction results in STOP mode being set.

Operand b3b2b1b0 of the STOP instruction indicates the STOP mode release conditions.

Table 17-4 STOP Mode Release Conditions

Format: STOP b3b2b1b0B

| Bit            | STOP mode release conditionNote 1                                |
|----------------|------------------------------------------------------------------|
| bз             | When this bit is 1, release by IRQxxx is permitted. Notes 2, 4   |
| b <sub>2</sub> | Always 0                                                         |
| b <sub>1</sub> | Always 0                                                         |
| bo             | When this bit is 1, release by RLS input is permitted. Note 3, 4 |

- Notes 1. When STOP 0000B is specified, STOP mode can be released only with reset (RESET input or POC).

  When STOP 0000B is executed, the microcomputer is initialized to the state existing immediately after the reset.
  - 2. IPxxx must be 1. STOP mode cannot be released with IRQTM1.
  - 3. Setting only b<sub>0</sub> to 1 is not allowed. (STOP 0001B is inhibited.) To set b<sub>0</sub> to 1, b<sub>3</sub> must also be set to
  - **4.** If the STOP instruction is executed when IRQ××× = 1 or when the RLS input is low, the STOP instruction is ignored (treated as a NOP instruction), and STOP mode is not set.

# 17.3.2 Starting Address After STOP Mode is Released

The starting address depends on the release conditions and interrupt enable conditions.

Table 17-5 Starting Address After STOP Mode is Released

| Release condition | Starting address after release                                                                                |
|-------------------|---------------------------------------------------------------------------------------------------------------|
| ResetNote 1       | Address 0                                                                                                     |
| RLS               | Address subsequent to the STOP instruction                                                                    |
| IRQ×××Note 2      | For DI, address subsequent to the STOP instruction                                                            |
|                   | For EI, interrupt vector (When more than one IRQxxx is set, the interrupt vector having the highest priority) |

- Notes 1. RESET input and POC are valid.
  - 2. IPxxx must be 1. STOP mode cannot be released with IRQTM1.



Fig. 17-2 Releasing STOP Mode (1/2)

# (a) Releasing STOP mode by RESET input



WAIT : Wait time until TM1 counts 256 source clock pulses (system clock/128)  $256 \times 128/fx + \alpha$  (approx. 4 ms +  $\alpha$  at fx = 8 MHz)

 $\alpha$ : Oscillation development time (which depends on the resonator)

# (b) Releasing STOP mode by RLS



WAIT : Wait time until TM1 counts (n + 1) source clock pulses (system clock/m) (n + 1)  $\times$  m/fx +  $\alpha$  (n and m are the values used immediately before STOP mode is set)

 $\alpha$ : Oscillation development time (which depends on the resonator)

# (c) Releasing STOP mode by IRQ××× (for DI)



WAIT : Wait time until TM1 counts (n + 1) source clock pulses (system clock/m) (n + 1)  $\times$  m/fx +  $\alpha$  (n and m are the values used immediately before STOP mode is set)

 $\alpha$ : Oscillation development time (which depends on the resonator)



Fig. 17-2 Releasing STOP Mode (2/2)

## (d) Releasing STOP mode by IRQ××× (for EI)



WAIT : Wait time until TM1 counts (n + 1) source clock pulses (system clock/m) (n + 1)  $\times$  m/fx +  $\alpha$  (n and m are the values used immediately before STOP mode is set)

 $\boldsymbol{\alpha}$  : Oscillation development time (which depends on the resonator)



## 18. RESET

The  $\mu$ PD17149 is reset when a reset signal is applied to the RESET pin, when the incorporated POC circuit detects a supply voltage drop, when the watchdog timer function detects a program crush, or when the address stack overflows or underflows. The incorporated POC circuit is specified with the mask option.

# **18.1 RESET FUNCTIONS**

The reset functions are used to initialize device operations. The operations initialized depend on the reset type.

Table 18-1 Hardware Statuses after Reset

|                                          |                   | RESET input during operation     Incorporated power-on/power-down reset during operation                                                 | RESET input in the standby mode Incorporated power-on/power-down reset in the standby mode | Watchdog timer<br>overflow     Stack overflow or<br>underflow                                        |  |
|------------------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|
| Program counter                          |                   | 0000H                                                                                                                                    | 0000H                                                                                      | 0000H                                                                                                |  |
| Port                                     | Input/output mode | Input                                                                                                                                    | Input                                                                                      | Input                                                                                                |  |
|                                          | Output latch      | 0                                                                                                                                        | 0                                                                                          | Not defined                                                                                          |  |
| General-purpose data memory              | Other than DBF    | Not defined                                                                                                                              | Statuses before reset are retained.                                                        | Not defined                                                                                          |  |
|                                          | DBF               | Not defined                                                                                                                              | Not defined                                                                                | Not defined                                                                                          |  |
| System register                          | Other than WR     | 0                                                                                                                                        | 0                                                                                          | 0                                                                                                    |  |
|                                          | WR                | Not defined                                                                                                                              | Statuses before reset are retained.                                                        | Not defined                                                                                          |  |
| Control register                         |                   | SP = 5H, IRQTM1 = 1, TM1EN = 1, IRQBTM = 0, and INT indicate the current status of the INT pin. The others are 0. See <b>Chapter 8</b> . |                                                                                            | SP = 5H and INT indicate the current status of the INT pin. The others retain statuses before reset. |  |
| Timer 0 and timer 1                      | Count register    | 00H                                                                                                                                      | 00Н                                                                                        | Timer 0: 00H Timer 1: Not defined                                                                    |  |
|                                          | Modulo register   | FFH                                                                                                                                      | FFH                                                                                        | FFH                                                                                                  |  |
| Basic interval timer binary counter      |                   | Not defined                                                                                                                              | Not defined                                                                                | Not defined.<br>(40H for watchdog timer<br>overflow)                                                 |  |
| Serial interface shift register (SIOSFR) |                   | Not defined                                                                                                                              | Statuses before reset are retained.                                                        | Not defined                                                                                          |  |
| A/D converter data reg                   | gister (ADCR)     | 00H                                                                                                                                      | 00H                                                                                        | 00H                                                                                                  |  |



Fig. 18-1 Reset Block Configuration



### 18.2 RESETTING

Operation when reset is caused by RESET input is shown in Fig. 18-2.

If the RESET pin is set from low to high, system clock generation starts and timer 1 generates an oscillation settling time. Program execution starts from address 0000H.

The controller also operates in the same way when the POC circuit causes a system reset.

At watchdog timer overflow reset or stack overflow and underflow reset, an oscillation settling time (WAIT) is not generated. Operation starts from address 0000H after initial statuses are internally set.



**Note** This is an oscillation settling time. Operating mode is set when timer 1 counts system clocks  $128 \times 256$  times (the execution time for approx. 2048 instructions, approx. 4 ms at 8 MHz).



## 19. POC CIRCUIT (MASK OPTION)

The POC circuit monitors the power supply voltage. It resets the microcomputer when the power is turned on/off. It can be used in application circuits using clock frequencies (fx) of between 400 kHz and 4 MHz.

The POC circuit can be included in the  $\mu$ PD17149 by specifying a mask option.

Caution The PROM product (µPD17P149) cannot include the POC circuit.

### 19.1 FUNCTIONS OF THE POC CIRCUIT

The POC circuit operates as follows:

- When V<sub>DD</sub> ≤ V<sub>POC</sub>, an internal reset signal is generated.
- When VDD > VPOC, the internal reset signal is released.
   (Where, VDD: power voltage, VPOC: POC-detected voltage)



Fig. 19-1 Operation of the POC Circuit

- **Notes 1.** In actual operation, an oscillation settling time, controlled by timer 1, is inserted before the operating mode is set. The oscillation settling time is equal to the time needed to execute approximately 2048 instructions (approximately 8 ms at fx = 4 MHz).
  - 2. A power supply voltage fall can cause a reset only when VPOC or a lower voltage level is maintained for a duration equal to at least the reset detection pulse width tsamp. Thus, there is a delay of up to tsamp before reset.
  - **3.** When the supply voltage (VDD) drops below 2.7 V, operations of all functions of the μPD17149 are unpredictable. The POC circuit, however, is designed to generate an internal reset signal whenever possible, regardless of whether an oscillation is received. So, an internal reset should occur when the voltage reaches a level at which the internal circuit can operate.
  - **4.** When the supply voltage rises abruptly (3 V/ms or more), even during operating mode, the POC circuit may generate an internal reset signal to prevent the program running away out of control.

**Remark** For the values of VPOC and tSAMP, see **Chapter 22**.



### 19.2 CONDITIONS UNDER WHICH THE POC CIRCUIT MAY BE USED

The POC circuit can be used when the application circuit satisfies the following conditions:

- · The application circuit is not required to provide high reliability.
- The supply voltage (VDD) of the application circuit is between 4.5 V and 5.5 V.
- The system clock frequency (fx) of the application circuit is between 400 kHz and 4 MHz.
- The supply voltage (VDD) characteristics satisfy the POC circuit specifications.

Cautions 1. When the POC circuit is used with an application circuit requiring high reliability, be sure to design the POC circuit so that the RESET signal is input from the outside.

2. When the POC circuit is used, the current drawn in standby mode will be slightly higher than when the circuit is not used.

Remark POC circuit operation is guaranteed when VDD is between 2.7 and 5.5 V.

## **★ 19.3 CAUTIONS FOR USING THE POC CIRCUIT**

The POC circuit is designed in a fail-safe configuration. It has an auxiliary function  $^{Note}$  by which if the supply voltage changes abruptly even within the rated range ( $V_{DD} = 4.5$  to 5.5 V), a reset signal is issued as much as possible to avoid program crashes.

Note that if the supply voltage does not meet the conditions listed below, the POC circuit may cause a reset.

- The variation (ĐV) of the supply voltage must be within 100 mV.
- If the variation of the supply voltage is not within 100 mV, the variation slant (ĐV/Đt) must be within 3 mV/µs.



**Note** The reset function based on supply voltage variation is of auxiliary nature. It does not assure that a reset occurs without failure. There is no condition to assure that a reset occurs based on this auxiliary function. Do not count on this function when designing.



# 20. INSTRUCTION SET

# 20.1 OVERVIEW OF THE INSTRUCTION SET

|         | <b>b</b> 15 |       |          |          |      |        |
|---------|-------------|-------|----------|----------|------|--------|
| b14-b11 |             |       | 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 |
|         |             | INC   | AR       |          |      |        |
|         |             | INC   | IX       |          |      |        |
|         |             | MOVT  | DBF, @AR |          |      |        |
|         |             | BR    | @AR      |          |      |        |
|         |             | CALL  | @AR      |          |      |        |
|         |             | RET   |          |          |      |        |
|         |             | RETSK |          |          |      |        |
|         |             | EI    |          |          |      |        |
|         |             | DI    |          |          |      |        |
| 0111    | 7           | RETI  |          |          |      |        |
|         | •           | PUSH  | AR       |          |      |        |
|         |             | POP   | AR       |          |      |        |
|         |             | GET   | DBF, p   |          |      |        |
|         |             | PUT   | p, DBF   |          |      |        |
|         |             | PEEK  | WR, rf   |          |      |        |
|         |             | POKE  | rf, WR   |          |      |        |
|         |             | RORC  | r        |          |      |        |
|         |             | STOP  | S        |          |      |        |
|         |             | HALT  | h        |          |      |        |
|         |             | NOP   |          |          |      |        |
| 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   |
| 1101    | D           | BR    | addr     | (page 1) | MOV  | m, #n4 |
| 1110    | Е           |       |          |          | SKT  | m, #n  |
| 1111    | F           |       |          |          | SKF  | m, #n  |



### 20.2 LEGEND

AR : Address register

ASR : Address stack register pointed to by the stack pointer

addr : Program memory address (11 low-order 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 in the stack when an interrupt occurs

INTSK : Interrupt stack register

IX : Index register

MP : Data memory row address pointer

MPE : Memory pointer enable flag

m : Data memory address specified by mR and mc

mc : Data memory row address (high-order)
mc : Data memory column address (low-order)

n : Bit position (four bits)n4 : Immediate data (four bits)

PAGE: Page (bit 11 of the program counter)

PC : Program counter p : Peripheral address

ph : Peripheral address (three high-order bits)
pL : Peripheral address (four low-order bits)

r : General register column address

rf : Register file address

rfR : Register file row address (three high-order bits)rfc : Register file column address (four low-order bits)

SP : Stack pointer

s : Stop release condition WR : Window register (x) : Contents of x



# 20.3 LIST OF THE INSTRUCTION SET

| Instruction | Mne-  | Operand  | Operation                                                                                                                                | Ir      | Instruction code |            |      |  |
|-------------|-------|----------|------------------------------------------------------------------------------------------------------------------------------------------|---------|------------------|------------|------|--|
| set         | monic | Орстана  | Operation                                                                                                                                | Op code | Op code Operand  |            |      |  |
| Add         | ADD   | r, m     | (r) ← (r) + (m)                                                                                                                          | 00000   | <b>m</b> R       | <b>m</b> c | r    |  |
|             |       | m, #n4   | (m) ← (m) + n4                                                                                                                           | 10000   | <b>m</b> R       | mc         | n4   |  |
|             | ADDC  | r, m     | $(r) \leftarrow (r) + (m) + CY$                                                                                                          | 00010   | <b>m</b> R       | <b>m</b> c | r    |  |
|             |       | m, #n4   | (m) ← (m) + n4 + CY                                                                                                                      | 10010   | <b>m</b> R       | mc         | n4   |  |
|             | INC   | AR       | AR ← AR + 1                                                                                                                              | 00111   | 000              | 1001       | 0000 |  |
|             |       | IX       | IX ← IX + 1                                                                                                                              | 00111   | 000              | 1000       | 0000 |  |
| Subtract    | SUB   | r, m     | (r) ← (r) - (m)                                                                                                                          | 00001   | MR               | mc         | r    |  |
|             |       | m, #n4   | (m) ← (m) - n4                                                                                                                           | 10001   | <b>m</b> R       | <b>m</b> c | n4   |  |
|             | SUBC  | r, m     | (r) ← (r) - (m) - CY                                                                                                                     | 00011   | mR               | mc         | r    |  |
|             |       | m, #n4   | (m) ← (m) - n4 - CY                                                                                                                      | 10011   | mR               | mc         | n4   |  |
| Logical     | OR    | r, m     | $(r) \leftarrow (r) \lor (m)$                                                                                                            | 00110   | mR               | mc         | r    |  |
| operation   |       | m, #n4   | (m) ← (m) ∨ n4                                                                                                                           | 10110   | <b>m</b> R       | <b>m</b> c | n4   |  |
|             | AND   | r, m     | (r) ← (r) ∧ (m)                                                                                                                          | 00100   | mR               | <b>m</b> c | r    |  |
|             |       | m, #n4   | (m) ← (m) ∧ n4                                                                                                                           | 10100   | mR               | mc         | n4   |  |
|             | XOR   | r, m     | $(r) \leftarrow (r) \lor (m)$                                                                                                            | 00101   | mR               | mc         | r    |  |
|             |       | m, #n4   | (m) ← (m) + n4                                                                                                                           | 10101   | mR               | mc         | n4   |  |
| Test        | SKT   | m, #n    | $CMP \leftarrow 0$ , if (m) $\wedge$ n = n, then skip                                                                                    | 11110   | mR               | mc         | n    |  |
|             | SKF   | m, #n    | $CMP \leftarrow 0$ , if (m) $\wedge$ n = 0, then skip                                                                                    | 11111   | <b>m</b> R       | <b>m</b> c | n    |  |
| Compare     | SKE   | m, #n4   | (m) - n4, skip if zero                                                                                                                   | 01001   | 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   | mR               | <b>m</b> c | n4   |  |
|             | SKLT  | m, #n4   | (m) - n4, skip if borrow                                                                                                                 | 11011   | mR               | mc         | n4   |  |
| Rotation    | RORC  | r        |                                                                                                                                          | 00111   | 000              | 0111       | r    |  |
| Transfer    | LD    | r, m     | (r) ← (m)                                                                                                                                | 01000   | <b>m</b> R       | <b>m</b> c | r    |  |
|             | ST    | m, r     | (m) ← (r)                                                                                                                                | 11000   | <b>m</b> R       | <b>m</b> c | r    |  |
|             | MOV   | @r, m    | if MPE = 1: (MP, (r)) $\leftarrow$ (m)<br>if MPE = 0: (BANK, m <sub>R</sub> , (r)) $\leftarrow$ (m)                                      | 01010   | <b>m</b> R       | <b>m</b> c | r    |  |
|             |       | m, @r    | if MPE = 1: (m) $\leftarrow$ (MP, (r))<br>if MPE = 0: (m) $\leftarrow$ (BANK, m <sub>R</sub> , (r))                                      | 11010   | МR               | <b>m</b> c | 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 ← ASR, SP ← SP + 1                                                                                                                    | 00111   | 000              | 1100       | 0000 |  |
|             | PEEK  | WR, rf   | WR ← (rf)                                                                                                                                | 00111   | rfR              | 0011       | rfc  |  |
|             | POKE  | rf, WR   | (rf) ← WR                                                                                                                                | 00111   | rfR              | 0010       | rfc  |  |
|             | GET   | DBF, p   | DBF ← (p)                                                                                                                                | 00111   | рн               | 1011       | рь   |  |
|             | PUT   | p, DBF   | (p) ← DBF                                                                                                                                | 00111   | рн               | 1010       | рь   |  |



| Instruction     | Mne-  | Operand | Operation                                                           | Ir      | Instruction code |      |      |  |
|-----------------|-------|---------|---------------------------------------------------------------------|---------|------------------|------|------|--|
| set             | monic | Operand | Operation                                                           | Op code | Operand          |      | I    |  |
| Branch          | BR    | addr    | Note                                                                | Note    |                  | addr |      |  |
|                 |       | @AR     | PC ← AR                                                             | 00111   | 000              | 0100 | 0000 |  |
| Sub-<br>routine | CALL  | addr    | $SP \leftarrow SP - 1$ , $ASR \leftarrow PC$ , $PC \leftarrow addr$ | 11100   |                  | addr |      |  |
|                 |       | @AR     | $SP \leftarrow SP - 1$ , $ASR \leftarrow PC$ , $PC \leftarrow AR$   | 00111   | 000              | 0101 | 0000 |  |
|                 | RET   |         | PC ← ASR, SP ← 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   | 100              | 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 following tables show the operations and op codes of a BR addr instruction for the  $\mu$ PD17145,  $\mu$ PD17147, and  $\mu$ PD17149.

# (a) $\mu$ PD17145, $\mu$ PD17147

| Mnemonic | Operand | Operation           | Op code |
|----------|---------|---------------------|---------|
| BR       | addr    | PC ← addr, PAGE ← 0 | 01100   |

# (b) $\mu$ PD17149

| Mnemonic | Operand | Operation           | Op code |
|----------|---------|---------------------|---------|
| BR       | addr    | PC ← addr, PAGE ← 0 | 01100   |
|          |         | PC ← addr, PAGE ← 1 | 01101   |



# 20.4 ASSEMBLER (AS17K) BUILT-IN MACRO INSTRUCTIONS

# Legend

flag n: Flag type symbol <> : Data <> is omissible.

|                     | Mnemonic | Operand                                       | Operation                                                                                                                                                                           | n         |
|---------------------|----------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
|                     | SKTn     | flag 1,flag n                                 | if (flag 1) to (flag n) = all "1", then skip                                                                                                                                        | 1 - n - 4 |
|                     | 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) ← 1                                                                                                                                                            | 1 - n - 4 |
| Duilt in            | CLRn     | flag 1,flag n                                 | (flag 1) to (flag n) $\leftarrow$ 0                                                                                                                                                 | 1 - n - 4 |
| Built-in macro NOTn | NOTn     | flag 1,flag n                                 | if (flag n) = "0", then (flag n) $\leftarrow$ 1<br>if (flag n) = "1", then (flag n) $\leftarrow$ 0                                                                                  | 1 - n - 4 |
|                     | INITFLG  | <not> flag 1,&lt;<not> flag n&gt;</not></not> | $ \label{eq:state-of-state-of-state}  \mbox{if description} = \mbox{NOT flag n, then (flag n)} \leftarrow 0 $ $ \mbox{if description} = \mbox{flag n, then (flag n)} \leftarrow 1 $ | 1 - n - 4 |
|                     | BANKn    |                                               | (BANK) ← n                                                                                                                                                                          | n = 0     |



## 21. ASSEMBLER RESERVED WORDS

### 21.1 MASK OPTION PSEUDO INSTRUCTIONS

The  $\mu PD17149$  has the following mask options.

- · Built-in pull-up resistor for pin RESET
- Built-in pull-up resistors for pins P0F1 and P0F0
- · Built-in pull-up resistor for pin INT
- · Incorporated POC circuit

Specify whether these mask options are used in the source program using mask-option-definition pseudo instructions.

# 21.1.1 Specifying Mask Options

Mask options are coded in the assembler source program with the following pseudo instructions.

- · OPTION and ENDOP pseudo instructions
- · Mask-option-definition pseudo instructions

## (1) OPTION and ENDOP pseudo instructions

These pseudo instructions specify the block in which mask options are coded (mask option definition block).

To specify a mask option, code the corresponding mask-option-definition pseudo instruction in the block enclosed with the OPTION pseudo instruction and ENDOP pseudo instruction.

| Fo | rmat:    |          |         |            |
|----|----------|----------|---------|------------|
|    | Symbol   | Mnemonic | Operand | Comment    |
|    | [label:] | OPTION   |         | [;comment] |
|    |          | :        |         |            |
|    |          | •        |         |            |
|    |          | :        |         |            |
|    |          | ENDOP    |         |            |



## (2) Mask option definition pseudo instructions

**Table 21-1 Mask Option Definition Pseudo Instructions** 

| Option                            | Definition pseudo instruction and format                    | Operand | Meaning                  |
|-----------------------------------|-------------------------------------------------------------|---------|--------------------------|
| Built-in pull-up resistor for pin | OPTRES <operand></operand>                                  | OPEN    | Without pull-up resistor |
| RESET                             |                                                             | PULLUP  | With pull-up resistor    |
| Built-in pull-up resistors for    | OPTP0F <operand-1>, <operand-2>Note</operand-2></operand-1> | OPEN    | Without pull-up resistor |
| pins P0F1 and P0F0                |                                                             | PULLUP  | With pull-up resistor    |
| Built-in pull-up resistor for pin | OPTINT <operand></operand>                                  | OPEN    | Without pull-up resistor |
| INT                               |                                                             | PULLUP  | With pull-up resistor    |
| Incorporated POC circuit          | OPTPOC <operand></operand>                                  | NOUSE   | Without POC circuit      |
|                                   |                                                             | USE     | With POC circuit         |

Note <

# (3) Example of specifying mask options

; Example of specifying mask options in  $\mu$ PD17149

## MASK\_OPTION:

OPTION ; Beginning of mask option definition block
OPTRES PULLUP ; RESET pin has the built-in pull-up resistor.

OPTP0F PULLUP, OPEN; P0F1 pin has the built-in pull-up resistor. P0F0 pin leaves open (external pull-

up).

OPTINT PULLUP ; INT pin has the built-in pull-up resistor.

OPTPOC NOUSE ; Internal POC circuit is not used.

ENDOP ; End of mask option definition block



# 21.2 RESERVED SYMBOLS

The reserved symbols defined in the  $\mu PD17149$  device file (AS17149) are listed below.

# System register (SYSREG)

| Symbolic name | Attribute | Value   | Read/<br>write | Description                           |
|---------------|-----------|---------|----------------|---------------------------------------|
| AR3           | MEM       | 0.74H   | R              | Bits 15 to 12 of the address register |
| AR2           | MEM       | 0.75H   | R/W            | Bits 11 to 8 of the address register  |
| AR1           | MEM       | 0.76H   | R/W            | Bits 7 to 4 of the address register   |
| AR0           | MEM       | 0.77H   | R/W            | Bits 3 to 0 of the 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            | Data memory row address 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            | Data memory row address 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 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                     |

Address 74H 75H 76H 77H 78H 79H 7AH 7BH 7CH 7DH 7EH 7FH Program Index register General Window Bank Address register register status Name register register Data memory (AR) pointer word (BANK) (WR) row address (PSWORD (RP) pointer (MP) IXH IXM AR0 RPH RPL PSW Symbol AR3 AR2 AR1 WR **BANK** IXL MPH MPL (IX) BCC 0 0 0 0 Note 2 0000P0000 CMYZX DataNote 1 0000 DΡ E (AR) (BANK) (RP) (MP) Initial value Not 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 when redefined set

Fig. 21-1 System Register Configuration

Notes 1. A bit indicating zero is fixed to zero.

2. Bit b<sub>3</sub> and b<sub>2</sub> of AR2 are always 0 for the  $\mu$ PD17145. Bit b<sub>3</sub> of AR2 is always 0 also for the  $\mu$ PD17147.



# Data buffer (DBF)

| Symbolic name | Attribute | Value | Read/<br>write | Description       |
|---------------|-----------|-------|----------------|-------------------|
| DBF3          | MEM       | 0.0CH | R/W            | DBF bits 15 to 12 |
| DBF2          | MEM       | 0.0DH | R/W            | DBF bits 11 to 8  |
| DBF1          | MEM       | 0.0EH | R/W            | DBF bits 7 to 4   |
| DBF0          | MEM       | 0.0FH | R/W            | DBF bits 3 to 0   |

# Port register

| Symbolic name | Attribute | Value   | Read/<br>write | Description   |
|---------------|-----------|---------|----------------|---------------|
| P0A3          | FLG       | 0.70H.3 | R/W            | Port 0A bit 3 |
| P0A2          | FLG       | 0.70H.2 | R/W            | Port 0A bit 2 |
| P0A1          | FLG       | 0.70H.1 | R/W            | Port 0A bit 1 |
| P0A0          | FLG       | 0.70H.0 | R/W            | Port 0A bit 0 |
| P0B3          | FLG       | 0.71H.3 | R/W            | Port 0B bit 3 |
| P0B2          | FLG       | 0.71H.2 | R/W            | Port 0B bit 2 |
| P0B1          | FLG       | 0.71H.1 | R/W            | Port 0B bit 1 |
| P0B0          | FLG       | 0.71H.0 | R/W            | Port 0B bit 0 |
| P0C3          | FLG       | 0.72H.3 | R/W            | Port 0C bit 3 |
| P0C2          | FLG       | 0.72H.2 | R/W            | Port 0C bit 2 |
| P0C1          | FLG       | 0.72H.1 | R/W            | Port 0C bit 1 |
| P0C0          | FLG       | 0.72H.0 | R/W            | Port 0C bit 0 |
| P0D3          | FLG       | 0.73H.3 | R/W            | Port 0D bit 3 |
| P0D2          | FLG       | 0.73H.2 | R/W            | Port 0D bit 2 |
| P0D1          | FLG       | 0.73H.1 | R/W            | Port 0D bit 1 |
| P0D0          | FLG       | 0.73H.0 | R/W            | Port 0D bit 0 |
| P0E3          | FLG       | 0.6EH.3 | R/W            | Port 0E bit 3 |
| P0E2          | FLG       | 0.6EH.2 | R/W            | Port 0E bit 2 |
| P0E1          | FLG       | 0.6EH.1 | R/W            | Port 0E bit 1 |
| P0E0          | FLG       | 0.6EH.0 | R/W            | Port 0E bit 0 |
| P0F1          | FLG       | 0.6FH.1 | R              | Port 0F bit 1 |
| P0F0          | FLG       | 0.6FH.0 | R              | Port 0F bit 0 |



# Register file (control register)

| Symbolic name | Attribute | Value   | Read/<br>write | Description                                                                                                          |
|---------------|-----------|---------|----------------|----------------------------------------------------------------------------------------------------------------------|
| SP            | MEM       | 0.81H   | R/W            | Stack pointer                                                                                                        |
| SIOTS         | FLG       | 0.82H.3 | R/W            | Serial interface start flag                                                                                          |
| SIOHIZ        | FLG       | 0.82H.2 | R/W            | Function selection flag for the P0D <sub>1</sub> /SO pin                                                             |
| SIOCK1        | FLG       | 0.82H.1 | R/W            | Bit 1 of source clock selection flag for the serial interface                                                        |
| SIOCK0        | FLG       | 0.82H.0 | R/W            | Bit 0 of source clock selection flag for the serial interface                                                        |
| WDTRES        | FLG       | 0.83H.3 | R/W            | Watchdog timer reset flag                                                                                            |
| WDTEN         | FLG       | 0.83H.0 | R/W            | Watchdog timer enable flag                                                                                           |
| TM10SEL       | FLG       | 0.8BH.3 | R/W            | Function selection flag for the P0D <sub>3</sub> /TM1OUT pin                                                         |
| SIOEN         | FLG       | 0.8BH.0 | R/W            | Serial interface enable flag                                                                                         |
| P0EGPU        | FLG       | 0.8CH.2 | R/W            | P0E group pull-up selection flag (1: Pull-up)                                                                        |
| P0BGPU        | FLG       | 0.8CH.1 | R/W            | P0B group pull-up selection flag (1: Pull-up)                                                                        |
| P0AGPU        | FLG       | 0.8CH.0 | R/W            | P0A group pull-up selection flag (1: Pull-up)                                                                        |
| P0DBPU3       | FLG       | 0.8DH.3 | R/W            | P0D₃ pull-up selection flag (1: Pull-up)                                                                             |
| P0DBPU2       | FLG       | 0.8DH.2 | R/W            | P0D <sub>2</sub> pull-up selection flag (1: Pull-up)                                                                 |
| P0DBPU1       | FLG       | 0.8DH.1 | R/W            | P0D <sub>1</sub> pull-up selection flag (1: Pull-up)                                                                 |
| P0DBPU0       | FLG       | 0.8DH.0 | R/W            | P0D <sub>0</sub> pull-up selection flag (1: Pull-up)                                                                 |
| INT           | FLG       | 0.8FH.0 | R              | INT pin status flag                                                                                                  |
| TM0EN         | FLG       | 0.91H.3 | R/W            | Timer 0 enable flag                                                                                                  |
| TM0RES        | FLG       | 0.91H.2 | R/W            | Timer 0 reset flag                                                                                                   |
| TM0CK1        | FLG       | 0.91H.1 | R/W            | Bit 1 of source clock selection flag for timer 0                                                                     |
| тмоско        | FLG       | 0.91H.0 | R/W            | Bit 0 of source clock selection flag for timer 0                                                                     |
| TM1EN         | FLG       | 0.92H.3 | R/W            | Timer 1 enable flag                                                                                                  |
| TM1RES        | FLG       | 0.92H.2 | R/W            | Timer 1 reset flag                                                                                                   |
| TM1CK1        | FLG       | 0.92H.1 | R/W            | Bit 1 of source clock selection flag for timer 1                                                                     |
| TM1CK0        | FLG       | 0.92H.0 | R/W            | Bit 0 of source clock selection flag for timer 1                                                                     |
| BTMISEL       | FLG       | 0.93H.3 | R/W            | Interrupt request clock selection flag for the basic interval timer                                                  |
| BTMRES        | FLG       | 0.93H.2 | R/W            | Basic interval timer reset flag                                                                                      |
| BTMCK1        | FLG       | 0.93H.1 | R/W            | Bit 1 of source clock selection flag for the basic interval timer                                                    |
| втмско        | FLG       | 0.93H.0 | R/W            | Bit 0 of source clock selection flag for the basic interval timer                                                    |
| P0C3IDI       | FLG       | 0.9BH.3 | R/W            | Input port disable flag for P0C <sub>3</sub> (pin function selection between ADC <sub>3</sub> and P0C <sub>3</sub> ) |
| P0C2IDI       | FLG       | 0.9BH.2 | R/W            | Input port disable flag for P0C <sub>2</sub> (pin function selection between ADC <sub>2</sub> and P0C <sub>2</sub> ) |
| P0C1IDI       | FLG       | 0.9BH.1 | R/W            | Input port disable flag for P0C <sub>1</sub> (pin function selection between ADC <sub>1</sub> and P0C <sub>1</sub> ) |
| P0C0IDI       | FLG       | 0.9BH.0 | R/W            | Input port disable flag for P0C <sub>0</sub> (pin function selection between ADC <sub>0</sub> and P0C <sub>0</sub> ) |
| P0CBIO3       | FLG       | 0.9CH.3 | R/W            | Input/output selection flag for P0C <sub>3</sub> (1: Output port)                                                    |
| P0CBIO2       | FLG       | 0.9CH.2 | R/W            | Input/output selection flag for P0C <sub>2</sub> (1: Output port)                                                    |
| P0CBIO1       | FLG       | 0.9CH.1 | R/W            | Input/output selection flag for P0C <sub>1</sub> (1: Output port)                                                    |
| P0CBIO0       | FLG       | 0.9CH.0 | R/W            | Input/output selection flag for P0C <sub>0</sub> (1: Output port)                                                    |
| IEGMD1        | FLG       | 0.9FH.1 | R/W            | Bit 1 of detection edge selection flag for the INT pin                                                               |
| IEGMD0        | FLG       | 0.9FH.0 | R/W            | Bit 0 of detection edge selection flag for the INT pin                                                               |



# Register file (control register)

| Symbolic name | Attribute | Value    | Read/<br>write | Description                                                                   |
|---------------|-----------|----------|----------------|-------------------------------------------------------------------------------|
| ADCSTRT       | FLG       | 0.0A0H.0 | R/W            | A/D converter start flag (always 0 when read)                                 |
| ADCSOFT       | FLG       | 0.0A1H.3 | R/W            | A/D converter operation mode selection flag (1: Single mode)                  |
| ADCCMP        | FLG       | 0.0A1H.1 | R              | A/D converter comparison result flag (valid only in the single mode)          |
| ADCEND        | FLG       | 0.0A1H.0 | R              | A/D converter conversion end flag                                             |
| ADCCH3        | FLG       | 0.0A2H.3 | R/W            | Dummy flag                                                                    |
| ADCCH2        | FLG       | 0.0A2H.2 | R/W            | Dummy flag                                                                    |
| ADCCH1        | FLG       | 0.0A2H.1 | R/W            | Bit 1 of channel selection flag for the A/D converter                         |
| ADCCH0        | FLG       | 0.0A2H.0 | R/W            | Bit 0 of channel selection flag for the A/D converter                         |
| P0DBIO3       | FLG       | 0.0ABH.3 | R/W            | Input/output selection flag for P0D <sub>3</sub> (1: Output port)             |
| P0DBIO2       | FLG       | 0.0ABH.2 | R/W            | Input/output selection flag for P0D₂ (1: Output port)                         |
| P0DBIO1       | FLG       | 0.0ABH.1 | R/W            | Input/output selection flag for P0D₁ (1: Output port)                         |
| P0DBIO0       | FLG       | 0.0ABH.0 | R/W            | Input/output selection flag for P0D₀ (1: Output port)                         |
| P0EGIO        | FLG       | 0.0ACH.2 | R/W            | Group input/output selection flag for P0E (1: All P0E pins are output ports.) |
| P0BGIO        | FLG       | 0.0ACH.1 | R/W            | Group input/output selection flag for P0B (1: All P0B pins are output ports.) |
| P0AGIO        | FLG       | 0.0ACH.0 | R/W            | Group input/output selection flag for P0A (1: All P0A pins are output ports.) |
| IPSIO         | FLG       | 0.0AEH.0 | R/W            | Interrupt enable flag for the serial interface                                |
| IPBTM         | FLG       | 0.0AFH.3 | R/W            | Interrupt enable flag for the basic interval timer                            |
| IPTM1         | FLG       | 0.0AFH.2 | R/W            | Interrupt enable flag for timer 1                                             |
| IPTM0         | FLG       | 0.0AFH.1 | R/W            | Interrupt enable flag for timer 0                                             |
| IP            | FLG       | 0.0AFH.0 | R/W            | Interrupt enable flag for the INT pin                                         |
| IRQSIO        | FLG       | 0.0BBH.0 | R/W            | Interrupt request flag for the serial interface                               |
| IRQBTM        | FLG       | 0.0BCH.0 | R/W            | Interrupt request flag for the basic interval timer                           |
| IRQTM1        | FLG       | 0.0BDH.0 | R/W            | Interrupt request flag for timer 1                                            |
| IRQTM0        | FLG       | 0.0BEH.0 | R/W            | Interrupt request flag for timer 0                                            |
| IRQ           | FLG       | 0.0BFH.0 | R/W            | Interrupt request flag for the INT pin                                        |



# Peripheral hardware register

| Symbolic name | Attribute | Value | Read/<br>write | Description                                                                                         |  |  |  |  |
|---------------|-----------|-------|----------------|-----------------------------------------------------------------------------------------------------|--|--|--|--|
| SIOSFR        | DAT       | 01H   | R/W            | Peripheral address of the shift register                                                            |  |  |  |  |
| ТМОМ          | DAT       | 02H   | W              | ripheral address of the timer 0 modulo register                                                     |  |  |  |  |
| TM1M          | DAT       | 03H   | W              | Peripheral address of the timer 1 modulo register                                                   |  |  |  |  |
| ADCR          | DAT       | 04H   | R/W            | Peripheral address of A/D converter data register                                                   |  |  |  |  |
| TM0TM1C       | DAT       | 45H   | R              | Peripheral address of timer 0 timer 1 count register                                                |  |  |  |  |
| AR            | DAT       | 40H   | R/W            | Peripheral address of the address register for GET, PUT, PUSH, CALL, BR, MOVT, and INC instructions |  |  |  |  |

# Others

| Symbolic name | Attribute | Value | Description                                        |
|---------------|-----------|-------|----------------------------------------------------|
| SDBF          | DAT       | 0FH   | Fixed operand value for a PUT/GET/MOVT instruction |
| IX            | DAT       | 01H   | Fixed operand value for an INC instruction         |



Fig. 21-2 Control Register Configuration (1/2)

| Colu     | ımn address    |                        |                                                     |                                                   |                                                         |                                         |   |                                         |   |
|----------|----------------|------------------------|-----------------------------------------------------|---------------------------------------------------|---------------------------------------------------------|-----------------------------------------|---|-----------------------------------------|---|
| Row      | ress Item      | 0                      | 1                                                   | 2                                                 | 3                                                       | 4                                       | 5 | 6                                       | 7 |
| 0 (8)    | Symbol         |                        | S P                                                 | S S S S S I I I I I I I I I I I I I I I           | W D D T T R O O E E N S                                 |                                         |   |                                         |   |
| (0)      | When reset     |                        | 0 1 0 1                                             | 0 0 0 0                                           | 0 0 0 0                                                 |                                         |   |                                         |   |
|          | Read/<br>Write |                        | R/W                                                 | R/W                                               | R/W                                                     |                                         |   |                                         |   |
| 1 (9)    | Symbol         |                        | T T T T M M M M 0 0 0 0 0 0 0 E R C C N E K K S 1 0 | T T T T M M M M 1 1 1 1 1 1 E R C C N E K K S 1 0 | B B B B B T T T T T M M M M M I R C C S E K K E S 1 0 L |                                         |   |                                         |   |
| (3)      | When reset     |                        | 0 0 0 0                                             | 1 0 0 0                                           | 0 0 0 0                                                 |                                         |   |                                         |   |
|          | Read/<br>Write |                        | R/W                                                 | R/W                                               | R/W                                                     |                                         |   |                                         |   |
| 2<br>(A) | Symbol         | 0 0 0 S<br>T<br>R<br>T | A                                                   | A A A A A D D D D C C C C C C H H H H H 3 2 1 0   |                                                         |                                         |   |                                         |   |
| ( ,      | When reset     | 0 0 0 0                | 0 0 0 0                                             | 0 0 0 0                                           |                                                         |                                         |   |                                         |   |
|          | Read/<br>Write | R/W                    | R/W R                                               | R/W                                               |                                                         |                                         |   |                                         |   |
| 3<br>(B) | Symbol         |                        |                                                     |                                                   |                                                         |                                         |   |                                         |   |
|          | When reset     | 1 1 1                  |                                                     | 1 1 1                                             | 1 1 1                                                   | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |   | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |   |
|          | Read/<br>Write |                        |                                                     |                                                   |                                                         |                                         |   |                                         |   |

Remark The address enclosed in parentheses apply when the AS17K assembler is used.

The names of all the flags in the control registers are assembler reserved words saved in the device file. Using these reserved words is useful in programming.

ŀΡ 0 Μ 0 0 0 0 0 E B G G P P D B P O E A G P D DDD Т 1 0 S E 0 0 0 B B B P P P 0 0 0 UUUU UUUU L 3 2 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 Note R/W R/W R/W R PPP PPP  $\pm i \pm$ 0 0 C C 0 0 C C 0 0 0 0 C C C C E E G G 1 0 M M 0 В BBBB DD DDDDD 0 0 0 0 0 1 1 1 1 1 1 3 2 1 0 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 0 0 0 0 R/W R/W R/W I I I P P P PP P P P 0 0 0 E B A 0 0 0 0 D D D D Р Ρ втт s BBBB 0 GGGG 0 0 0 1 T M M M 1 1 0 0 0 0 0 0 0 0 0 3 2 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 R/W R/W R/W R/W 1 R R Q B Q T Q Q 0 0 0 0 0 0 S 0 0 0 0 0 0 0 0 0 Т M 0 Μ

Fig. 21-2 Control Register Configuration (2/2)

Note The INT flag depends on the status of the INT pin.

0 0 0 0

R/W

0 0 0 1

R/W

0 0 0 1

R/W

0 0 0 0

R/W

0 0 0 0

R/W



#### 22. ELECTRICAL CHARACTERISTICS

# ABSOLUTE MAXIMUM RATINGS (TA = 25 °C)

| Parameter                       | Symbol               |                                                     | Condition | าร                            | Rated value                   | Unit |
|---------------------------------|----------------------|-----------------------------------------------------|-----------|-------------------------------|-------------------------------|------|
| Supply voltage                  | V <sub>DD</sub>      |                                                     |           |                               | -0.3 to +7.0                  | V    |
| A/D converter reference voltage | Vref                 |                                                     |           |                               | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Input voltage                   | Vı                   | P0A, P0B, P0C<br>RESET, and XII                     |           | , P0F, INT,                   | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Output voltage                  | Vo                   |                                                     |           | -0.3 to V <sub>DD</sub> + 0.3 | V                             |      |
| High-level output current       | I <sub>OH</sub> Note | Each of P0A, P                                      | ЮВ,       | Peak value                    | -15                           | mA   |
|                                 |                      | and P0C pins                                        |           | rms                           | -7.5                          | mA   |
|                                 |                      | Total of P0A, P0B,                                  |           | Peak value                    | -30                           | mA   |
|                                 |                      | and P0C pins                                        |           | rms                           | -15                           | mA   |
| Low-level output current        | <sub> OL</sub> Note  | Each of P0A, P0B,<br>and P0C<br>Each of P0D and P0E |           | Peak value                    | 15                            | mA   |
|                                 |                      |                                                     |           | rms                           | 7.5                           | mA   |
|                                 |                      |                                                     |           | Peak value                    | 30                            | mA   |
|                                 |                      |                                                     |           | rms                           | 15                            | mA   |
|                                 |                      | Total of P0A, P                                     | 0B,       | Peak value                    | 100                           | mA   |
|                                 |                      | P0C, P0D, and                                       | P0E pins  | rms                           | 50                            | mA   |
| Operating ambient temperature   | TA                   |                                                     |           |                               | -40 to +85                    | °C   |
| Storage temperature             | Tstg                 |                                                     |           |                               | -65 to +150                   | °C   |
| Allowable dissipation           | Pd                   |                                                     |           | lastic shrink DIP             | 140                           | mW   |
|                                 |                      |                                                     |           | lastic SOP                    | 85                            | mW   |

**Note** Calculate a root-mean-square value as follows: [rms value] = [peak value]  $\times \sqrt{\text{duty}}$ .

Caution Absolute maximum ratings are rated values beyond which some physical damages may be caused to the product; if any of the parameters in the table above exceeds its rated value even for a moment, the quality of the product may deteriorate. Be sure to use the product within the rated values.

# RECOMMENDED POWER VOLTAGE RANGE (T<sub>A</sub> = -40 to +85 °C)

| Parameter      | Symbol          |                              | Conditions                                                                               | Min. | Тур. | Max. | Unit     |
|----------------|-----------------|------------------------------|------------------------------------------------------------------------------------------|------|------|------|----------|
| Supply voltage | V <sub>DD</sub> | CPU                          | fx = 400  kHz to  2  MHz                                                                 | 2.7  |      | 5.5  | ٧        |
|                |                 | (except A/D converter        | fx = 400  kHz to  4  MHz                                                                 | 3.6  |      | 5.5  | V        |
|                |                 | and POC circuit)             | fx = 400  kHz to  8  MHz                                                                 | 4.5  |      | 5.5  | V        |
|                |                 | A/D converter                | Absolute accuracy: $\pm 1.5$ LSB, $2.5$ V $\leq$ V <sub>REF</sub> $\leq$ V <sub>DD</sub> | 4.0  |      | 5.5  | <b>V</b> |
|                |                 | POC circuit<br>(mask option) | fx = 400 kHz to 4 MHz                                                                    | 4.5  |      | 5.5  | V        |

\*



### DC CHARACTERISTICS (V<sub>DD</sub> = 2.7 to 5.5 V, T<sub>A</sub> = -40 to +85 °C)

| Parameter                         | Symbol           |                         | Conditions                             |                                                         | Min.                  | Тур. | Max.               | Unit |
|-----------------------------------|------------------|-------------------------|----------------------------------------|---------------------------------------------------------|-----------------------|------|--------------------|------|
| High-level input                  | V <sub>IH1</sub> | P0A, P0B, P0C           | C, P0D, P0E, and                       | I P0F                                                   | 0.7V <sub>DD</sub>    |      | V <sub>DD</sub>    | V    |
| voltage                           | V <sub>IH2</sub> | RESET, SCK,             | SI, and INT                            |                                                         | 0.8V <sub>DD</sub>    |      | V <sub>DD</sub>    | V    |
|                                   | VIH3             | Xin                     | V <sub>DD</sub> - 0.5                  |                                                         | V <sub>DD</sub>       | V    |                    |      |
| Low-level input                   | V <sub>IL1</sub> | P0A, P0B, P0C           | C, P0D, P0E, and                       | I P0F                                                   | 0                     |      | 0.3V <sub>DD</sub> | V    |
| voltage                           | V <sub>IL2</sub> | RESET, SCK, SI, and INT |                                        |                                                         | 0                     |      | 0.2V <sub>DD</sub> | V    |
|                                   | VIL3             | Xin                     |                                        |                                                         | 0                     |      | 0.4                | V    |
| High-level output voltage         | Vон              | P0A, P0B, and           | P0C                                    | 4.5 - V <sub>DD</sub> - 5.5<br>Іон = -1.0 mA            | V <sub>DD</sub> - 0.3 |      |                    | V    |
|                                   |                  |                         |                                        | 2.7 - V <sub>DD</sub> < 4.5<br>Іон = -0.5 mA            | V <sub>DD</sub> - 0.3 |      |                    | V    |
| Low-level output voltage          | V <sub>OL1</sub> | P0A, P0B, P0C           | C, P0D, and P0E                        | 4.5 - V <sub>DD</sub> - 5.5<br>lo <sub>L</sub> = 1.0 mA |                       |      | 0.3                | V    |
|                                   |                  |                         |                                        | 2.7 - V <sub>DD</sub> < 4.5<br>I <sub>OL</sub> = 0.5 mA |                       |      | 0.3                | V    |
|                                   | V <sub>OL2</sub> | P0D and P0E             |                                        | 4.5 - VDD - 5.5                                         |                       |      | 1.0                | V    |
|                                   |                  | IoL = 15 mA             |                                        | 2.7 - VDD < 4.5                                         |                       |      | 2.0                | V    |
| High-level input leakage current  | Ін               | P0A, P0B, P0C           | , P0D, P0E, P0F,                       | RESET, and INT VIN = VDD                                |                       |      | 3                  | μΑ   |
| Low-level input leakage current   | Іш               | P0A, P0B, P0C           | , P0D, P0E, P0F,                       | RESET, and INT<br>V <sub>IN</sub> = 0 V                 |                       |      | -3                 | μΑ   |
| High-level output leakage current | Ісон             | P0A, P0B, P0C,          | P0A, P0B, P0C, P0D, and P0E Vout = VdD |                                                         |                       |      | 3                  | μΑ   |
| Low-level output leakage current  | ILOL             | P0A, P0B, P0C,          | , P0D, and P0E                         | Vout = 0 V                                              |                       |      | -3                 | μΑ   |
| Built-in pull-up                  | Rpull            | P0A, P0B, P0E           | 50                                     | 100                                                     | 200                   | kΩ   |                    |      |
| resistance <sup>Note</sup> 1      |                  | P0D                     |                                        |                                                         | 3                     | 10   | 30                 | kΩ   |
| Power supply                      | I <sub>DD1</sub> | Normal                  | fx = 8.0 MHz,                          | V <sub>DD</sub> = 5 V ±10 %                             |                       | 2.0  | 4.5                | mA   |
| currentNote 2                     |                  | operation               | fx = 4.0 MHz,                          | fx = 4.0 MHz, V <sub>DD</sub> = 5 V ±10 %               |                       | 1.4  | 3.3                | mA   |
|                                   |                  | mode                    | fx = 2.0 MHz,                          | fx = 2.0 MHz, V <sub>DD</sub> = 5 V ±10 %               |                       | 1.0  | 2.5                | mA   |
|                                   |                  |                         | fx = 2.0 MHz,                          | fx = 2.0 MHz, V <sub>DD</sub> = 3 V ±10 %               |                       | 0.8  | 2.5                | mA   |
|                                   |                  |                         | fx = 1.0 MHz,                          | V <sub>DD</sub> = 5 V ±10 %                             |                       | 0.7  | 2.0                | mA   |
|                                   |                  |                         | fx = 400 kHz                           | V <sub>DD</sub> = 5 V ±10 %                             |                       | 0.9  | 1.7                | mA   |
|                                   |                  |                         |                                        | V <sub>DD</sub> = 3 V ±10 %                             |                       | 0.3  | 1.0                | mA   |
|                                   | I <sub>DD2</sub> | HALT mode               | fx = 8.0 MHz,                          | V <sub>DD</sub> = 5 V ±10 %                             |                       | 1.0  | 2.0                | mA   |
|                                   |                  |                         | fx = 4.0  MHz,                         | V <sub>DD</sub> = 5 V ±10 %                             |                       | 0.9  | 1.9                | mA   |
|                                   |                  |                         | fx = 2.0 MHz,                          | fx = 2.0 MHz, VDD = 3 V ±10 %                           |                       | 0.5  | 1.7                | mA   |
|                                   |                  |                         | fx = 1.0 MHz,                          | V <sub>DD</sub> = 5 V ±10 %                             |                       | 0.5  |                    | mA   |
|                                   |                  |                         | fx = 400 kHz                           | V <sub>DD</sub> = 5 V ±10 %                             |                       | 0.7  | 1.5                | mA   |
|                                   |                  |                         |                                        | V <sub>DD</sub> = 3 V ±10 %                             |                       | 0.3  | 0.9                | mA   |
|                                   | I <sub>DD3</sub> | STOP mode               | V <sub>DD</sub> = 5 V ±10              |                                                         | 1                     | 3.0  | 10                 | μΑ   |
|                                   |                  |                         | V <sub>DD</sub> = 3 V ±10              |                                                         | 2.0                   | 10   | μA                 |      |

Notes 1. The pull-up resistors for the P0F, RESET, and INT pins are specified with mask options.

2. This current excludes the current which flows through the A/D converter, POC circuit, and built-in pull-up resistors.

\*

\*



# AC CHARACTERISTICS (VDD = 2.7 to 5.5 V, $T_A$ = -40 to +85 °C)

| Parameter                                   | Symbol        | Conditions                     | Min. | Тур. | Max. | Unit |
|---------------------------------------------|---------------|--------------------------------|------|------|------|------|
| CPU clock cycle time                        | tcy           | V <sub>DD</sub> = 4.5 to 5.5 V | 1.9  |      | 41   | μs   |
| (instruction execution time)                |               | V <sub>DD</sub> = 3.6 to 5.5 V | 3.9  |      | 41   | μs   |
|                                             |               |                                | 7.9  |      | 41   | μs   |
| INT input frequency (TM0 count clock input) | fint          |                                | 0    |      | 400  | kHz  |
| INT high/low level width                    | tinth,        | V <sub>DD</sub> = 4.5 to 5.5 V | 10   |      |      | μs   |
| (external interrupt input)                  | tintl         |                                | 50   |      |      | μs   |
| RESET low-level width                       | trsl          | V <sub>DD</sub> = 4.5 to 5.5 V | 10   |      |      | μs   |
|                                             |               |                                | 50   |      |      | μs   |
| RLS low-level width                         | <b>t</b> RLSL | V <sub>DD</sub> = 4.5 to 5.5 V | 10   |      |      | μs   |
|                                             |               |                                | 50   |      |      | μs   |

**Remark** tcy = 16/fx (fx: frequency of system clock oscillator)

### Interrupt input timing



# **RESET** input timing



# RLS input timing





### SERIAL TRANSFER OPERATION (VDD = 2.7 to 5.5 V, TA = -40 to +85 °C)

| Parameter                                                 | Symbol       |                  | Conditions                                                                                 |                                | Min.               | Тур. | Max. | Unit |
|-----------------------------------------------------------|--------------|------------------|--------------------------------------------------------------------------------------------|--------------------------------|--------------------|------|------|------|
| SCK cycle time                                            | <b>t</b> KCY | Input            | V <sub>DD</sub> = 4.5 to 5.5 V                                                             |                                |                    |      |      | μs   |
|                                                           |              | lnk              |                                                                                            | 10                             |                    |      | μs   |      |
|                                                           |              |                  | R <sub>L</sub> = 1 kΩ, C <sub>L</sub> = 100 pF                                             | V <sub>DD</sub> = 4.5 to 5.5 V | 2.0                |      |      | μs   |
|                                                           |              | Output           |                                                                                            |                                | 8                  |      |      | μs   |
|                                                           |              | Out              | Built-in pull-up resistor,                                                                 | V <sub>DD</sub> = 4.5 to 5.5 V | 32                 |      |      | μs   |
|                                                           |              |                  | C <sub>L</sub> = 100 pF                                                                    |                                | 64                 |      |      | μs   |
| width                                                     | tкн,         | Input            | V <sub>DD</sub> = 4.5 to 5.5 V                                                             |                                | 1.0                |      |      | μs   |
|                                                           | tĸL          | t <sub>KL</sub>  |                                                                                            |                                | 5.0                |      |      | μs   |
|                                                           |              | Output           | $R_L = 1 \text{ k}\Omega$ , $C_L = 100 \text{ pF}$                                         | V <sub>DD</sub> = 4.5 to 5.5 V | tkcy/2-0.6         |      |      | μs   |
|                                                           |              |                  |                                                                                            |                                | <b>t</b> KCY/2-1.2 |      |      | μs   |
|                                                           |              | Out              | Built-in pull-up resistor,                                                                 | V <sub>DD</sub> = 4.5 to 5.5 V | tkcy/2-12          |      |      | μs   |
|                                                           |              |                  | C <sub>L</sub> = 100 pF                                                                    |                                | tkcy/2-24          |      |      | μs   |
| SI setup time (with respect to $\overline{SCK}$ )         | tsıĸ         |                  |                                                                                            |                                | 100                |      |      | ns   |
| SI hold time (with respect to $\overline{SCK} \uparrow$ ) | tĸsı         |                  |                                                                                            |                                | 100                |      |      | ns   |
| Delay from SCK↓ to                                        | <b>t</b> kso | RL =             | = 1 kΩ, C∟ = 100 pF                                                                        | V <sub>DD</sub> = 4.5 to 5.5 V |                    |      | 0.8  | μs   |
| SO                                                        |              |                  |                                                                                            |                                |                    |      | 1.4  | μs   |
|                                                           |              |                  | Built-in pull-up resistor, $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}$ $C_L = 100 \text{ pF}$ |                                |                    |      | 14   | μs   |
|                                                           |              | C <sub>L</sub> = |                                                                                            |                                |                    |      | 26   | μs   |

**Remark** R<sub>L</sub>: a resistive load for the output line C<sub>L</sub>: a capacitive load for the output line









### A/D CONVERTER ( $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, T_A = -40 \text{ to } +85 ^{\circ}\text{C}$ )

| Parameter                         | Symbol | Conditions                      | Min. | Тур. | Max.            | Unit |
|-----------------------------------|--------|---------------------------------|------|------|-----------------|------|
| Resolution                        |        |                                 | 8    | 8    | 8               | bit  |
| Absolute accuracyNote 1           |        | 2.5 V ≤ VREF ≤ VDD              |      |      | ±1.5            | LSB  |
| Conversion time <sup>Note 2</sup> | tconv  |                                 |      |      | 25 tcy          | μs   |
| Analog signal input voltage       | Vadin  |                                 | 0    |      | VREF            | V    |
| Reference input voltage           | VREF   |                                 | 2.5  |      | V <sub>DD</sub> | V    |
| A/D converter circuit current     | IADC   | When A/D converter is operating |      | 1.0  | 2.0             | mA   |
| V <sub>REF</sub> pin current      | IREF   |                                 |      | 0.1  | 0.3             | mA   |

**Notes 1.** Absolute accuracy excluding quantization error (±0.5 LSB)

2. Time from conversion start instruction execution to conversion end (ADCEND = 1) (at fx = 8 MHz, 50  $\mu$ s).

**Remark** tcy = 16/fx (fx: frequency of system clock oscillator)

### POC CIRCUIT (MASK OPTIONNote 1) (VDD = 2.7 to 5.5 V, TA = -40 to +85 °C)

| Parameter                   | Symbol        | Conditions | Min. | Тур. | Max. | Unit |
|-----------------------------|---------------|------------|------|------|------|------|
| POC detection voltageNote 2 | VPOC          |            | 3.6  | 4.0  | 4.45 | V    |
| Supply voltage fall speed   | tpocs         |            |      |      | 0.08 | V/ms |
| Reset detection pulse width | <b>t</b> samp |            | 1    |      |      | ms   |
| POC circuit current         | Ірос          |            |      | 3.0  | 10   | μΑ   |

- **Notes 1.** This circuit can be used in an application circuit where  $V_{DD}$  is 4.5 to 5.5 V and the clock frequency (fx) ranges from 400 kHz to 4 MHz.
  - 2. This is the voltage at which the POC circuit releases the internal reset. When  $V_{POC}$  becomes less than  $V_{DD}$ , the internal reset is released.



### CHARACTERISTICS OF THE SYSTEM CLOCK OSCILLATOR (VDD = 2.7 to 5.5 V, TA = -40 to +85 °C)

| Resonator Note    | Parameter   | Conditions                     | Min. | Тур. | Max. | Unit |
|-------------------|-------------|--------------------------------|------|------|------|------|
| Ceramic resonator | Oscillation |                                | 0.39 |      | 2.04 | MHz  |
|                   | frequency   | V <sub>DD</sub> = 3.6 to 5.5 V | 0.39 |      | 4.08 | MHz  |
|                   | (fx)        | V <sub>DD</sub> = 4.5 to 5.5 V | 0.39 |      | 8.16 | MHz  |

Note Do not use a resonator having an oscillation generation time of 2 ms or more.

### RECOMMENDED CERAMIC RESONATORS (TA = -40 to +85 °C)

| Manufacturer | Part number    | Reco                | mmended con            | stants  | Supply volt | age [V]Note 1 | Remarks                   |  |
|--------------|----------------|---------------------|------------------------|---------|-------------|---------------|---------------------------|--|
| Manufacturer | Fait liulibei  | C1 [pF]             | C2 [pF]                | Rd [kΩ] | Min.        | Max.          | Remarks                   |  |
| Murata Mfg.  | CSB400P        | 220                 | 220                    | 5.6     | 2.7         | 5.5           |                           |  |
|              | CSA2. 00MG040  | 100                 | 100                    | 0       | 2.7         | 5.5           |                           |  |
|              | CST2. 00MG040  | Not requ            | ired <sup>Note 2</sup> | 0       | 2.7         | 5.5           |                           |  |
|              | CSA4. 00MG     | 30                  | 30                     | 0       | 3.6         | 5.5           |                           |  |
|              | CST4. 00MGW    | Not requ            | ired <sup>Note 2</sup> | 0       | 3.6         | 5.5           |                           |  |
|              | CSA8. 00MG     | 30                  | 30                     | 0       | 4.5         | 5.5           |                           |  |
|              | CST8. 00MGW    | Not requ            | ired <sup>Note 2</sup> | 0       | 4.5         | 5.5           |                           |  |
|              | CSB400JA       | 220                 | 220                    | 5.6     | 2.7         | 5.5           |                           |  |
|              | CSA2. 00MGA040 | 100                 | 100                    | 0       | 2.7         | 5.5           |                           |  |
|              | CST2. 00MGA040 | Not requ            | ired <sup>Note 2</sup> | 0       | 2.7         | 5.5           | Electrical                |  |
|              | CSA4. 00MGA    | 30                  | 30                     | 0       | 3.6         | 5.5           | equipment for automobiles |  |
|              | CST4. 00MGWA   | Not required Note 2 |                        | 0       | 3.6         | 5.5           | automobiles               |  |
|              | CSA8. 00MTZA   | 30                  | 30                     | 0       | 4.5         | 5.5           |                           |  |
|              | CST8. 00MTWA   | Not requiredNote 2  |                        | 0       | 4.5         | 5.5           |                           |  |
| Kyocera      | KBR-400BK      | 470                 | 470                    | 0       | 2.7         | 5.5           |                           |  |
|              | KBR-2. 0MS     | 47                  | 47                     | 0       | 2.7         | 5.5           |                           |  |
|              | KBR-4. 0MSA    | 33                  | 33                     | 0       | 3.6         | 5.5           |                           |  |
|              | KBR-8. 0M      | 33                  | 33                     | 0       | 4.5         | 5.5           |                           |  |
| TDK          | FCR400K3       | 330                 | 330                    | 0       | 2.7         | 5.5           |                           |  |
|              | FCR2. 0M3      | 100                 | 100                    | 0       | 2.7         | 5.5           |                           |  |
|              | FCR2. 0MC3     | Not requ            | ired <sup>Note 2</sup> | 1.5     | 2.7         | 5.5           |                           |  |
|              | FCR4. 0M5      | 33                  | 33                     | 0       | 3.6         | 5.5           |                           |  |
|              | CCR4. 0MC3     | Not requ            | ired <sup>Note 2</sup> | 0       | 3.6         | 5.5           |                           |  |
|              | FCR4. 0MC5     | Not requ            | ired <sup>Note 2</sup> | 0       | 3.6         | 5.5           |                           |  |
|              | FCR8. 0M2S     | 33                  | 33                     | 0       | 4.5         | 5.5           |                           |  |
|              | FCR8. 0MC      | Not requ            | ired <sup>Note 2</sup> | 0       | 4.5         | 5.5           |                           |  |

Notes 1. When the POC circuit (mask option) is not used

2. Capacitors are contained.

Example of an external circuit



# **NEC**

# 23. CHARACTERISTIC CURVES (FOR REFERENCE)





Caution Absolute maximum rating of output current is 15 mA (peak value) per pin.



Caution Absolute maximum rating of output current is 30 mA (peak value) per pin.



Caution Absolute maximum rating of output current is -15 mA (peak value) per pin.



### 24. PACKAGE DRAWINGS

PACKAGE DRAWINGS OF MASS-PRODUCED PRODUCTS (1/2)

# 28 PIN PLASTIC SHRINK DIP (400 mil)







#### **NOTES**

- 1) Each lead centerline is located within 0.17 mm (0.007 inch) of its true position (T.P.) at maximum material condition.
- 2) Item "K" to center of leads when formed parallel.

| ITEM | MILLIMETERS                            | INCHES                    |
|------|----------------------------------------|---------------------------|
| Α    | 28.46 MAX.                             | 1.121 MAX.                |
| В    | 2.67 MAX.                              | 0.106 MAX.                |
| С    | 1.778 (T.P.)                           | 0.070 (T.P.)              |
| D    | 0.50±0.10                              | $0.020^{+0.004}_{-0.005}$ |
| F    | 0.85 MIN.                              | 0.033 MIN.                |
| G    | 3.2±0.3                                | 0.126±0.012               |
| Н    | 0.51 MIN.                              | 0.020 MIN.                |
| I    | 4.31 MAX.                              | 0.170 MAX.                |
| J    | 5.08 MAX.                              | 0.200 MAX.                |
| K    | 10.16 (T.P.)                           | 0.400 (T.P.)              |
| L    | 8.6                                    | 0.339                     |
| М    | 0.25 <sup>+0.10</sup> <sub>-0.05</sub> | $0.010^{+0.004}_{-0.003}$ |
| N    | 0.17                                   | 0.007                     |
| R    | 0Å15°                                  | 0Å15°                     |
|      |                                        | S20C 70 400B 1            |

S28C-70-400B-1

Caution The ES is different from the corresponding mass-produced products in shape and material. See "ES PACKAGE DRAWINGS (1/2)."



#### PACKAGE DRAWINGS OF MASS-PRODUCED PRODUCTS (2/2)

### 28 PIN PLASTIC SOP (375 mil)



detail of lead end







**NOTE** 

Each lead centerline is located within 0.12 mm (0.005 inch) of its true position (T.P.) at maximum material condition.

P28GT-50-375B-1

| ITEM | MILLIMETERS            | INCHES                             |
|------|------------------------|------------------------------------|
| Α    | 18.2 MAX.              | 0.717 MAX.                         |
| В    | 0.845 MAX.             | 0.034 MAX.                         |
| С    | 1.27 (T.P.)            | 0.050 (T.P.)                       |
| D    | $0.40^{+0.10}_{-0.05}$ | $0.016^{+0.004}_{-0.003}$          |
| Е    | 0.125±0.075            | 0.005±0.003                        |
| F    | 2.9 MAX.               | 0.115 MAX.                         |
| G    | 2.50±0.2               | $0.098\substack{+0.009 \\ -0.008}$ |
| Н    | 10.3±0.3               | $0.406\substack{+0.012 \\ -0.013}$ |
| I    | 7.2±0.2                | $0.283^{+0.009}_{-0.008}$          |
| J    | 1.6±0.2                | 0.063±0.008                        |
| K    | $0.15^{+0.10}_{-0.05}$ | $0.006\substack{+0.004 \\ -0.002}$ |
| L    | 0.8±0.2                | $0.031^{+0.009}_{-0.008}$          |
| М    | 0.12                   | 0.005                              |
| N    | 0.10                   | 0.004                              |

Caution The ES is different from the corresponding mass-produced products in shape and material. See "ES PACKAGE DRAWINGS (2/2)."



### **ES PACKAGE DRAWINGS (1/2)**

# 28 PIN CERAMIC SHRINK DIP (400mil) (FOR ES)







## NOTES

- 1) Each lead centerline is located within 0.25 mm (0.01 inch) of its true position (T.P.) at maximum material condition.
- 2) Item "K" to center of leads when formed parallel.

| ITEM | MILLIMETERS  | INCHES                    |
|------|--------------|---------------------------|
| Α    | 28.0 MAX.    | 1.103 MAX.                |
| В    | 5.1 MAX.     | 0.201 MAX.                |
| С    | 1.778 (T.P.) | 0.070 (T.P.)              |
| D    | 0.46±0.05    | 0.018±0.002               |
| F    | 0.8 MIN.     | 0.031 MIN.                |
| G    | 3.0±1.0      | 0.118±0.04                |
| Н    | 1.0 MIN.     | 0.039 MIN.                |
| I    | 2.7          | 0.106                     |
| J    | 4.3 MAX.     | 0.170 MAX.                |
| K    | 10.16 (T.P.) | 0.400 (T.P.)              |
| L    | 9.84         | 0.387                     |
| М    | 0.25±0.05    | $0.010^{+0.002}_{-0.003}$ |
| N    | 0.25         | 0.010                     |
| R    | 0~15°        | 0~15°                     |

P28D-70-400B-1



### **ES PACKAGE DRAWINGS (2/2)**

# 28 PIN CERAMIC SOP (FOR ES)



### NOTE

The lengths of leads (1) and the height of potting (2) are not to be specified because the lead cutting process and the potting process are not controlled.

| ITEM | MILLIMETERS | INCHES                    |
|------|-------------|---------------------------|
| Α    | 18.0±0.2    | $0.709^{+0.008}_{-0.009}$ |
| С    | 1.27 (T.P.) | 0.05 (T.P.)               |
| D    | 0.4±0.05    | $0.016^{+0.002}_{-0.003}$ |
| G    | 1.52±0.15   | 0.06±0.006                |
| 1    | 8.4±0.15    | $0.331^{+0.006}_{-0.007}$ |
| J    | 16.4        | 0.646                     |
| K    | 0.15±0.025  | 0.006±0.001               |
| Т    | 1.0         | 0.039                     |
|      |             |                           |

X28B-50B1



#### **★ 25. RECOMMENDED SOLDERING CONDITIONS**

The conditions listed below shall be met when soldering this product.

For details of the recommended soldering conditions, refer to our document *SMD Surface Mount Technology Manual* (C10535E).

Please consult with our sales offices in case any other soldering process is used, or in case soldering is done under different conditions.

Table 25-1 Soldering Conditions for Surface-Mount Devices

 μPD17145GT-xxx:
 28-pin plastic SOP (375 mil)

 μPD17147GT-xxx:
 28-pin plastic SOP (375 mil)

 μPD17149GT-xxx:
 28-pin plastic SOP (375 mil)

 μPD17147GT(A)-xxx:
 28-pin plastic SOP (375 mil)

 μPD17149GT(A)-xxx:
 28-pin plastic SOP (375 mil)

 μPD17149GT(A)-xxx:
 28-pin plastic SOP (375 mil)

| Soldering process      | Soldering conditions                                                                                                                                                                                                                                                                                                                                   | Symbol     |
|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| Infrared ray reflow    | Peak package's surface temperature: 235 °C Reflow time: 30 seconds or less (at 210 °C or more) Maximum allowable number of reflow processes: 2 Exposure limitNote: 7 days (20 hours of pre-baking is required at 125 °C afterward.) <caution> Non-heat resistant trays, such as magazine and taping trays, cannot be baked before unpacking.</caution> | IR35-207-2 |
| VPS                    | Peak package's surface temperature: 215 °C Reflow time: 40 seconds or less (at 200 °C or more) Maximum allowable number of reflow processes: 2 Exposure limitNote: 7 days (20 hours of pre-baking is required at 125 °C afterward.) <caution> Non-heat resistant trays, such as magazine and taping trays, cannot be baked before unpacking.</caution> | VP15-207-2 |
| Partial heating method | Terminal temperature: 300 °C or less Heat time: 3 seconds or less (for each side of device)                                                                                                                                                                                                                                                            | -          |

**Note** Exposure limit before soldering after dry-pack package is opened.

Storage conditions: Temperature of 25 °C and maximum relative humidity at 65 % or less

Caution Do not apply more than a single process at once, except for "Partial heating method."



Table 25-2 Soldering Conditions for Through Hole Mount Devices

 $\begin{array}{lll} \mu \text{PD17145CT-} \times \times \times & 28\text{-pin plastic shrink DIP (400 mil)} \\ \mu \text{PD17147CT-} \times \times \times & 28\text{-pin plastic shrink DIP (400 mil)} \\ \mu \text{PD17149CT-} \times \times \times & 28\text{-pin plastic shrink DIP (400 mil)} \\ \mu \text{PD17147CT(A)-} \times \times \times & 28\text{-pin plastic shrink DIP (400 mil)} \\ \mu \text{PD17149CT(A)-} \times \times \times & 28\text{-pin plastic shrink DIP (400 mil)} \\ \mu \text{PD17149CT(A)-} \times \times \times & 28\text{-pin plastic shrink DIP (400 mil)} \\ \end{array}$ 

| Soldering process              | Soldering conditions                                                                     |
|--------------------------------|------------------------------------------------------------------------------------------|
| Wave soldering (only for pins) | Solder temperature: 260 °C or less Flow time: 10 seconds or less                         |
| Partial heating method         | Terminal temperature: 300 °C or less<br>Heat time: 3 seconds or less (for each terminal) |

Caution In wave soldering, apply solder only to the pins. Care must be taken that jet solder does not come in contact with the main body of the package.







# APPENDIX B. COMPARISON OF FUNCTIONS OF $\mu \text{PD17145}$ SUB-SERIES, $\mu \text{PD17135A},$ AND $\mu \text{PD17137A}$

|                |                                              | μPD17145                                                                                                                                                                   | μPD17147                                                        | μPD17149 | μPD17135A                                                                                                        | μPD17137A     |  |
|----------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|----------|------------------------------------------------------------------------------------------------------------------|---------------|--|
| ROM            |                                              | 2K bytes                                                                                                                                                                   | 4K bytes                                                        | 8K bytes | 2K bytes                                                                                                         | 4K bytes      |  |
| RAM            |                                              |                                                                                                                                                                            | 110 × 4 bits                                                    |          | 112 ×                                                                                                            | 4 bits        |  |
| Stack          |                                              |                                                                                                                                                                            | Five levels of address stack Three levels of interrupt stack    |          |                                                                                                                  |               |  |
|                | ction execution time<br>, operating voltage) | $2 \mu s$ (fx = 8 MHz, V <sub>DD</sub> = 4.5 to 5.5 V)<br>$4 \mu s$ (fx = 4 MHz, V <sub>DD</sub> = 3.6 to 5.5 V)<br>$8 \mu s$ (fx = 2 MHz, V <sub>DD</sub> = 2.7 to 5.5 V) |                                                                 |          | $2 \mu s$ (fx = 8 MHz, V <sub>DD</sub> = 4.5 to 5.5 V)<br>$4 \mu s$ (fx = 4 MHz, V <sub>DD</sub> = 2.7 to 5.5 V) |               |  |
| I/O CMOS I/O   |                                              |                                                                                                                                                                            |                                                                 | 12 (P0   | A, P0B, P0C)                                                                                                     |               |  |
|                | Dedicated to input                           |                                                                                                                                                                            | 2 (P0F <sub>0</sub> , P0F <sub>1</sub> )                        |          | 1 (F                                                                                                             | °1B₀)         |  |
|                | Sense input                                  | 1 (INT)<br>Pull-up by                                                                                                                                                      | mask option enat                                                | oled     | 1 (1                                                                                                             | NT)           |  |
|                | N-ch open-drain I/O                          | P0D pull-u                                                                                                                                                                 | DE Withstand volt<br>p resistor : Softwa<br>p resistor : Softwa | are      | 8 (P0D, P1A Withstand voltage : 9 V)<br>P0D pull-up resistor : Mask option<br>P1A pull-up resistor : Mask option |               |  |
| Built-i        | n pull-up resistance                         |                                                                                                                                                                            | 100 kΩ TYP. (other than P0D)<br>10 kΩ TYP. (P0D)                |          |                                                                                                                  | Ω TYP.        |  |
|                | onverter<br>ating voltage)                   | Four 8-bit channels (VDD = 4.0 to 5.5 V)                                                                                                                                   |                                                                 |          | Four 8-bit channels<br>(V <sub>DD</sub> = 4.5 to 5.5 V)                                                          |               |  |
|                | Reference voltage pin                        | VREF (VREF = 2.5 V to VDD)                                                                                                                                                 |                                                                 |          | None (VREF = VADC = VDD)                                                                                         |               |  |
| Timer          | 8-bit (TM0, TM1)                             | 2 (Timer output : TM1OUT)  TM0 clock : fx/512                                                                                                                              |                                                                 | fx/2     | 256<br>64<br>16<br>T                                                                                             |               |  |
|                | Basic interval (BTM)                         |                                                                                                                                                                            | ed as a watchdog<br>k: fx/16384<br>fx/4096<br>fx/512<br>fx/16   | timer)   | 1 (Also used as a watchdog t<br>Count clock : fx/8192<br>fx/4096<br>TM0 count-up<br>INT                          |               |  |
| Inter-<br>rupt | External                                     | 1                                                                                                                                                                          |                                                                 |          | 1 (AC zero cross detection is performed.)                                                                        |               |  |
|                | Internal                                     | 4 (TM0, TM1, BTM, SIO)                                                                                                                                                     |                                                                 |          |                                                                                                                  |               |  |
| SIO            |                                              | 1 (Synchronous                                                                                                                                                             |                                                                 |          | s three-wire)                                                                                                    |               |  |
|                | Output latch                                 | Ind                                                                                                                                                                        | ependent of P0D                                                 | latch    | Also used f                                                                                                      | or P0D₁ latch |  |
| Stanb          | y function                                   | HALT, STOP (Input pin RLS is provided for cancellation.)  HALT, S                                                                                                          |                                                                 |          | STOP                                                                                                             |               |  |
| Oscilla        | ation settling time                          |                                                                                                                                                                            | 128 × 256 count                                                 |          | 512×2                                                                                                            | 256 count     |  |
|                |                                              | -                                                                                                                                                                          |                                                                 |          |                                                                                                                  |               |  |

\*



|               | μPD17145                                                      | μPD17147       | μPD17149 | μPD17135A  | μPD17137A |  |
|---------------|---------------------------------------------------------------|----------------|----------|------------|-----------|--|
| POC function  | Mask option Built-in                                          |                |          | lt-in      |           |  |
| Package       | 28-pin plastic SDIP (400 mil)<br>28-pin plastic SOP (375 mil) |                |          |            |           |  |
| One-time PROM |                                                               | $\mu$ PD17P149 |          | μPD17P137A |           |  |

Caution  $\mu$ PD17145 sub-series,  $\mu$ PD17135A, and  $\mu$ PD17137A are not pin-compatible. Furthermore, the  $\mu$ PD17145 sub-series does not feature units that are equivalent to the  $\mu$ PD17134A and  $\mu$ PD17136A (RC oscillation type). For the electrical characteristics of these units, refer to the data sheet for each unit.



#### APPENDIX C. DEVELOPMENT TOOLS

The following support tools are available for developing programs for the  $\mu$ PD17145,  $\mu$ PD17147,  $\mu$ PD17149,  $\mu$ PD17145(A),  $\mu$ PD17147(A), and  $\mu$ PD17149(A).

#### Hardware

| Name                                                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| In-circuit emulator  [IE-17K IE-17K-ETNote 1 EMU-17KNote 2                        | The IE-17K, IE-17K-ET, and EMU-17K are in-circuit emulators applicable to the 17K series. The IE-17K and IE-17K-ET are connected to the PC-9800 series (host machine) or IBM PC/AT <sup>TM</sup> through the RS-232-C interface. The EMU-17K is inserted into the extension slot of the PC-9800 series (host machine). Use the system evaluation board (SE board) corresponding to each product together with one of these in-circuit emulators. <i>SIMPLEHOST</i> <sup>TM</sup> , a man machine interface, implements an advanced debug environment. The EMU-17K also enables user to check the contents of the data memory in real time. |
| SE board<br>(SE-17145)                                                            | The SE-17145 is an SE board for the $\mu$ PD17145 sub-series. It is used solely for evaluating the system. It is also used for debugging in combination with the in-circuit emulator.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Emulation probe<br>(EP-17K28CT)                                                   | The EP-17K28CT is an emulation probe for the 17K series 28-pin shrink DIP (400 mil).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Emulation probe<br>(EP-17K28GT)                                                   | The EP-17K28GT is an emulation probe for the 17K series 28-pin SOP (375 mil). Use this probe together with the conversion adapter EV-9500GT-28 <sup>Note 3</sup> , to check the target system with the corresponding SE board.                                                                                                                                                                                                                                                                                                                                                                                                             |
| Conversion adapter (EV-9500GT-28 <sup>Note 3</sup> )                              | The EV-9500GT-28 is an adapter for the 28-pin SOP (375 mil). Use this conversion adapter to connect the emulation probe, EP-17K28GT, to the target system.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| PROM programmerNote 4  AF-9703Note 4  AF-9704Note 4  AF-9705Note 4  AF-9706Note 4 | The AF-9703, AF-9704, AF-9705, and AF-9706 are PROM programmers for the $\mu$ PD17P149. Use one of these PROM programmers with the program adapter, AF-9808M, to program the $\mu$ PD17P149.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Programmer adapterNote 4 (AF-9808M)                                               | The AF-9808M is a socket unit for the $\mu$ PD17P149. It is used with the AF-9703, AF-9704, AF-9705, or AF-9706.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

Notes 1. Low-end model, operating on an external power supply

- 2. The EMU-17K is a product of I.C Corporation. Contact I.C Corporation (Tokyo, 03-3447-3793) for details.
- **3.** An EP-17K28GT is supplied together with two EV-9500GT-28s. A set of five EV-9500GT-28s is also available.
- **4.** The AF-9703, AF-9704, AF-9705, AF-9706, and AF-9808M are products of Ando Electric Co., Ltd. Contact Ando Electric Co., Ltd. (Tokyo, 03-3733-1163) for details.

\*



#### Software

| Name                               | Description                                                                                                                                                        | Host OS machine   |                      | Distribution media | Part number    |               |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------|--------------------|----------------|---------------|
| 17K series<br>assembler<br>(AS17K) | AS17K is an assembler applicable to the 17K series.                                                                                                                | PC-9800<br>series | MS-DOS <sup>TM</sup> |                    | 5.25-inch, 2HD | μS5A10AS17K   |
|                                    | In developing $\mu$ PD17145, $\mu$ PD17147, or $\mu$ PD17149 programs, AS17K is used in combination with a device file (AS17145).                                  |                   |                      |                    | 3.5-inch, 2HD  | μS5A13AS17K   |
|                                    |                                                                                                                                                                    | IBM<br>PC/AT      | PC DOS <sup>TM</sup> |                    | 5.25-inch, 2HC | μS7B10AS17K   |
|                                    |                                                                                                                                                                    |                   |                      |                    | 3.5-inch, 2HC  | μS7B13AS17K   |
| Device file<br>(AS17145)           | AS17145 contains device files for the $\mu$ PD17145, $\mu$ PD17147, and                                                                                            | PC-9800<br>series | MS-DOS               |                    | 5.25-inch, 2HD | μS5A10AS17145 |
|                                    | $\mu$ PD17149. They are used together with the assembler (AS17K) which is applicable to the 17K series.                                                            |                   |                      |                    | 3.5-inch, 2HD  | μS5A13AS17145 |
|                                    |                                                                                                                                                                    | IBM<br>PC/AT      | PC DOS               |                    | 5.25-inch, 2HC | μS7B10AS17145 |
|                                    |                                                                                                                                                                    |                   |                      |                    | 3.5-inch, 2HC  | μS7B13AS17145 |
| Support software (SIMPLEHOST)      | SIMPLEHOST, running on the Windows <sup>TM</sup> , provides man-machine-interface in developing programs by using a personal computer and the in-circuit emulator. | PC-9800<br>series | MS-DOS               | - Windows -        | 5.25-inch, 2HD | μS5A10IE17K   |
|                                    |                                                                                                                                                                    |                   |                      |                    | 3.5-inch, 2HD  | μS5A13IE17K   |
|                                    |                                                                                                                                                                    | IBM<br>PC/AT      | PC DOS               |                    | 5.25-inch, 2HC | μS7B10IE17K   |
|                                    |                                                                                                                                                                    |                   |                      |                    | 3.5-inch, 2HC  | μS7B13IE17K   |

**Remark** The following table lists the versions of the operating systems described in the above table.

| os      | Versions                    |
|---------|-----------------------------|
| 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 versions 5.00 and 5.00A and PC DOS Ver. 5.0 are provided with a task swap function. This function, however, cannot be used in these software packages.



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

Santa Clara, 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.**

Velizy-Villacoublay, 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: 08-63 80 820 Fax: 08-63 80 388

#### **NEC Electronics Hong Kong Ltd.**

Hong Kong Tel: 2886-9318 Fax: 2886-9022/9044

#### **NEC Electronics Hong Kong Ltd.**

Seoul Branch Seoul, Korea Tel: 02-528-0303 Fax: 02-528-4411

### **NEC Electronics Singapore Pte. Ltd.**

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



SIMPLEHOST is a 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.

M4 96.5