## PRELIMINARY PRODUCT INFORMATION

# MOS INTEGRATED CIRCUIT $\mu$ PD780921, 780922, 780923, 780924

## 8-BIT SINGLE-CHIP MICROCONTROLLER

The µPD780921, 780922, 780923, and 780924, which are members of the µPD780924 subseries of the 78K/0 series, are suited to control general-purpose inverters.

Compared to the conventional µPD78014 subseries or µPD78018F subseries products, EMI (Electro Magnetic Interface) noise is reduced for the µPD780924 subseries products.

A flash memory version, the µPD78F0924, that can operate within the same power supply voltage range as the mask ROM version, and various development tools are also provided.

## The details of functions are described in the following user's manuals. Be sure to read them before designing. μPD780924 Subseries User's Manual : Planned 78K/0 Series User's Manual Instructions : IEU-1372

#### FEATURES

Internal ROM and RAM

EL

| Item<br>Part Number | Program memory<br>(ROM) | Data memory<br>(internal high-capacity RAM) | Package                                             |
|---------------------|-------------------------|---------------------------------------------|-----------------------------------------------------|
| μPD780921           | 8 Kbytes                | 512 bytes                                   | 64-pin plastic shrink DIP (750 mil)                 |
| μPD780922           | 16 Kbytes               |                                             | <ul> <li>64-pin plastic QFP (14 x 14 mm)</li> </ul> |
| µPD780923           | 24 Kbytes               | 1024 bytes                                  |                                                     |
| μPD780924           | 32 Kbytes               |                                             |                                                     |

- External memory expansion space: 48 Kbytes
- Minimum instruction execution time: 0.24 μs (@ fx = 8.38-MHz operation)
- I/O ports: 47
- 8-bit resolution A/D converter: eight channels
- Serial interface: two channels
- Timer: Five channels
- Power supply voltage: VDD = 2.7 to 5.5 V

#### **APPLICATIONS**

Motor control for inverter-type air conditioners, washing machines, etc.

The information in this document contains applications using a device in advance of the production cycle. The parameters for the device may change before final production or NEC Corporation, at its own discretion, may withdraw the device prior to its production.
Document No. U11804EJ1V0PM00 (1st edition)
Date Published November 1996 N
Printed in Japan
© NEC Corporation 1996

\_

2

\_ . \_ \_ \_ \_

ſ

## ORDERING INFORMATION

| Part Number         | Package                             |
|---------------------|-------------------------------------|
| μPD780921CW-xxx     | 64-pin plastic shrink DIP (750 mil) |
| μPD780922CW-xxx     | 64-pin plastic shrink DIP (750 mil) |
| μPD780923CW-xxx     | 64-pin plastic shrink DIP (750 mil) |
| μPD780924CW-xxx     | 64-pin plastic shrink DIP (750 mil) |
| μPD780921GC-xxx-AB8 | 64-pin plastic QFP (14 x 14 mm)     |
| μPD780922GC-×××-AB8 | 64-pin plastic QFP (14 x 14 mm)     |
| µPD780923GC-×××-AB8 | 64-pin plastic QFP (14 x 14 mm)     |
| μPD780924GC-xxx-AB8 | 64-pin plastic QFP (14 x 14 mm)     |

Remark xxx indicates the ROM code suffix.

🖬 6427525 009940l ll7 🛤

\_\_\_\_

3

## **78K/0 SERIES DEVELOPMENT**

The 78K/0 series product line-up is shown below. Subseries names are shown inside frames.



Note Under planning

**6**427525 0099402 053 **III** 

\_\_\_\_\_

|                  | Functions  | ROM          |       | Tir    | ner   |     | 8-bit | 8-bit | Serial           | 1/0 | Vod<br>MIN. | External  |
|------------------|------------|--------------|-------|--------|-------|-----|-------|-------|------------------|-----|-------------|-----------|
| Subseries        |            | Capacity     | 8-bit | 16-bit | Watch | WDT | A/D   | D/A   | Interface        | 1/0 | Value       | Expansion |
| For Control      | µPD78078   | 32 K to 60 K | 4ch   | 1ch    | 1ch   | 1ch | 8ch   | 2ch   | 3ch (UART: 1ch)  | 88  | 1.8 V       | Available |
|                  | µPD78070A  | —            |       |        |       |     |       |       |                  | 61  | 2.7 V       | 1         |
|                  | µPD780018  | 48 K to 60 K |       | 1      |       |     |       |       | 2ch              | 88  |             |           |
|                  | µPD78058F  |              | 2ch   | 1      |       |     | ł     | 2ch   | 3ch (UART : 1ch) | 69  |             |           |
|                  | µPD78054   | 16 K to 60 K |       |        |       |     |       |       |                  |     | 2.0 V       | 1         |
|                  | µPD780924  | 8 K to 32K   | 3ch   | Note   | —     |     |       | _     | 2ch (UART : 2ch) | 47  | 2.7ch       |           |
|                  | µPD78018F  | 8 K to 60 K  | 2ch   | 1ch    | 1ch   |     |       |       | 2ch              | 53  | 1.8 V       | 1         |
|                  | µPD78014   | 8 K to 32 K  |       |        |       |     |       |       |                  |     | 2.7 V       | -<br>     |
|                  | µPD780001  | 8 K          |       | _      | -     |     |       |       | 1ch              | 39  |             | _         |
|                  | µPD78002   | 8 K to 16 K  |       |        | 1ch   |     |       |       |                  | 53  |             | Available |
|                  | µPD78083   | 8 K to 16 K  |       |        | -     |     | Bch   | 1     | 1ch (UART : 1ch) | 33  | 1.8 V       | - 1       |
| For FIP          | µPD780208  | 32 K to 60 K | 2ch   | 1ch    | 1ch   | 1ch | 8ch   |       | 2ch              | 74  | 2.7 V       | _         |
| drive            | µPD78044F  | 16 K to 40 K |       |        |       |     |       |       |                  | 68  |             |           |
|                  | µPD78024   | 24 K to 32 K |       |        |       |     |       |       |                  | 54  |             |           |
| For LCD          | µPD780308  | 48 K to 60 K | 2ch   | 1ch    | 1ch   | 1ch | 8ch   |       | 3ch (UART: 1ch)  | 57  | 1.8 V       | -         |
| drive            | µPD78064B  | 32 K         |       |        |       |     |       |       | 2ch (UART : 1ch) | 1   | 2.0 V       | 1         |
|                  | µPD78064   | 16 K to 32 K |       |        |       |     |       |       |                  |     |             |           |
| IEBus<br>Support | µPD78098   | 32 K to 60 K | 2ch   | 1ch    | 1ch   | 1ch | 8ch   | 2ch   | 3ch (UART: 1ch)  | 69  | 2.7 V       | Available |
| For LV           | µPD78P0914 | 32K          | 6ch   | -      | _     | 1ch | 8ch   | _     | 2ch              | 54  | 4.5 V       | Available |

The table below shows the main differences between subseries.

Note 10-bit timer: one channel

4

## 64275250099403 T9T 🖿

Powered by ICminer.com Electronic-Library Service CopyRight 2003

- .....

## **FUNCTION OVERVIEW**

|                      | Product Name               |                                                                         |                           |                          |                              |  |  |  |
|----------------------|----------------------------|-------------------------------------------------------------------------|---------------------------|--------------------------|------------------------------|--|--|--|
| Item                 |                            | μPD780921                                                               | μPD780922                 | µPD780923                | μPD780924                    |  |  |  |
| internal             | ROM                        | 8 Kbytes                                                                | 16 Kbytes                 | 24 Kbytes                | 32 Kbytes                    |  |  |  |
| memory               | Internal<br>high-speed RAM | 512 bytes                                                               |                           | 1024 bytes               |                              |  |  |  |
| Memory sp            | ace                        | 64 Kbytes                                                               |                           |                          |                              |  |  |  |
| General-pu           | rpose register             | 8 bits x 32 registers (8                                                | bits x 8 registers x 4 ba | nks)                     |                              |  |  |  |
| Instruction          | cycle                      | On-chip instruction exc                                                 | ecution time variable fun | ction                    | a <u>1995 - 19</u> 11 - 1911 |  |  |  |
| Instruction          |                            |                                                                         | us/1.9 μs/3.8 μs (@ 8.38- | MHz operation with syste | m clock)                     |  |  |  |
| instruction          | set                        | 16-bit operation                                                        |                           |                          |                              |  |  |  |
|                      |                            | <ul> <li>Multiply/divide (8 bits x 8 bits, 16 bits + 8 bits)</li> </ul> |                           |                          |                              |  |  |  |
|                      |                            | Bit manipulate (set, reset, test, Boolean operation)                    |                           |                          |                              |  |  |  |
|                      |                            | BCD adjust, etc.                                                        |                           |                          |                              |  |  |  |
| I/O ports            |                            | Total : 47                                                              |                           |                          |                              |  |  |  |
|                      |                            | CMOS inputs : 8                                                         |                           |                          |                              |  |  |  |
|                      |                            | CMOS I/Os : 39                                                          |                           |                          |                              |  |  |  |
|                      | output ports               | 8 bits x 1 or 4 bits x 2                                                |                           |                          |                              |  |  |  |
| A/D conver           | ter                        | B-bit resolution x 8 channels                                           |                           |                          |                              |  |  |  |
|                      |                            | Power supply voltage: AVob = 2.7 to 5.5 V                               |                           |                          |                              |  |  |  |
| Serial inter         | face                       | UART x 2 channels                                                       |                           |                          |                              |  |  |  |
| Timer                |                            | 8-bit timer/event counter : 3 channels                                  |                           |                          |                              |  |  |  |
|                      |                            | • 10-bit timer : 1 channel                                              |                           |                          |                              |  |  |  |
|                      |                            | Watchdog timer : 1 channel                                              |                           |                          |                              |  |  |  |
| Timer outp           |                            | 9 (8-bit PWM output x 3, and inverter control output x 6)               |                           |                          |                              |  |  |  |
| Vectored             | Maskable interrupts        | Internal: 12, external: 4                                               |                           |                          |                              |  |  |  |
| interrupt            | Non-maskable interrupt     | Internal: 1                                                             |                           |                          |                              |  |  |  |
| Software interrupt   |                            | 1                                                                       |                           |                          |                              |  |  |  |
| Power supply voltage |                            | Voo = 2.7 to 5.5 V                                                      |                           |                          |                              |  |  |  |
|                      | mbient temperature         | T <sub>A</sub> = -40 to +85 °C                                          |                           |                          |                              |  |  |  |
| Package              |                            | <ul> <li>64-pin plastic shrink</li> </ul>                               | DIP (750 mil)             |                          |                              |  |  |  |
|                      |                            | • 64-pin plastic QFP (14 x 14 mm)                                       |                           |                          |                              |  |  |  |

## ■ 6427525 0099404 926 **■**

\_

NEC

## CONTENTS

| 1.  | PIN CONFIGURATION (TOP VIEW)              | 7  |
|-----|-------------------------------------------|----|
| 2.  | BLOCK DIAGRAM                             | 10 |
| 3.  | PIN FUNCTION LIST                         |    |
|     | 3.1 PORT PINS                             |    |
|     | 3.2 NON PORT PINS                         | 12 |
|     | 3.3 RECOMMENDED CONNECTION OF UNUSED PINS | 13 |
| 4.  | MEMORY SPACE                              | 14 |
| 5.  | PERIPHERAL HARDWARE FUNCTION FEATURES     | 15 |
|     | 5.1 PORTS                                 |    |
|     | 5.2 CLOCK GENERATOR                       |    |
|     | 5.3 TIMER/EVENT COUNTERS                  | 17 |
|     | 5.4 REAL-TIME OUTPUT PORT                 | 19 |
|     | 5.5 A/D CONVERTER                         | 20 |
|     | 5.6 SERIAL INTERFACE                      | 21 |
| 6.  | INTERRUPT FUNCTIONS                       | 22 |
| 7.  | EXTERNAL DEVICE EXPANSION FUNCTION        | 25 |
| 8.  | STANDBY FUNCTIONS                         | 25 |
| 9.  | RESET FUNCTIONS                           | 25 |
| 10. |                                           | 26 |
| 11. | PACKAGE DRAWINGS                          | 29 |
| AP  | PENDIX A. DEVELOPMENT TOOLS               | 31 |
| AP  | PENDIX B. RELATED DOCUMENTS               | 33 |

6

## 1. PIN CONFIGURATION (Top View)

• 64-Pin Plastic Shrink DIP (750 mil) μPD780921CW-xxx, 780922CW-xxx, 780923CW-xxx, 780924CW-xxx



## Cautions 1. Connect the TEST pin to Vsso directly.

- 2. Connect the AVpp pin to Vppo.
- 3. Connect the AVss pin to Vsso.
- Remark When the μPD780921, 780922, 780923, or 780924 is used in application fields that require reduction of the noise generated from inside the microcontroller, the implementation of noise reduction measures, such as supplying voltage to Vodo and Vss1 individually and connecting Vsso and Vss1 to different ground lines, is recommended.

#### 🖬 6427525 0099406 7T9 📰

NEC

## • 64-Pin Plastic QFP (14 x 14 mm) μPD780921GC-xxx-AB8, 780922GC-xxx-AB8, 780923GC-xxx-AB8, 780924GC-xxx-AB8



#### Cautions 1. Connect the TEST pin to Vsso directly.

- 2. Connect the AVDD pin to VDDO.
- 3. Connect the AVss pin to Vsso.

8

Remark When the μPD780921, 780922, 780923, or 780924 is used in application fields that require reduction of the noise generated from inside the microcontroller, the implementation of noise reduction measures, such as supplying voltage to Vodo and Vss1 individually and connecting Vsso and Vss1 to different ground lines, is recommended.

## | 6427525 0099407 635 🖿

9

| P00 to P03<br>P10 to P17<br>P20 to P26<br>P30 to P37<br>P40 to P47<br>P50 to P57 | <ul> <li>Address Bus</li> <li>Address/Data Bus</li> <li>AD Trigger Input</li> <li>Analog Input</li> <li>Address Strobe</li> <li>Analog Power Supply</li> <li>Analog Reference Voltage</li> <li>Analog Ground</li> <li>Interrupt From Peripherals</li> <li>Port 0</li> <li>Port 1</li> <li>Port 2</li> <li>Port 3</li> <li>Port 4</li> <li>Port 5</li> <li>Port 6</li> </ul> | RD           RESET           RTP0 to RTP7           RxD00, RxD01           TEST           T150 to T152           TO50 to T052,           TO70 to T075           TOFF7           TxD00, TxD01           Vsso, Vss1           WAIT           WR           X1, X2 |  | Read Strobe<br>Reset<br>Real-time Port<br>Receive Data<br>Test<br>Timer Input<br>Timer Output<br>Timer Output Off<br>Transmit Data<br>Power Supply<br>Ground<br>Wait<br>Write Strobe<br>Crystal |  |
|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|

🔲 6427525 0099408 571 🔜

NEC

## 2. BLOCK DIAGRAM



6427525 0099409 408 🔳

Remark Internal ROM and RAM capacity varies depending on the product.

10

## 3. PIN FUNCTION LIST

## 3.1 PORT PINS

| Pin Name   | 1/0   | Function                                                       | After Reset | Alternate<br>Function |
|------------|-------|----------------------------------------------------------------|-------------|-----------------------|
| P00        | 1/0   | Port 0.                                                        | Input       | INTP0/TOFF7           |
| P01        |       | 4-bit I/O port.                                                |             | INTP1                 |
| P02        |       | Input/output can be specified bit-wise.                        |             | INTP2                 |
| P03        | 7     | When used as an input port, an on-chip pull-up resistor can be |             | INTP3/ADTRG           |
|            |       | connected by software.                                         |             |                       |
| P10 to P17 | Input | Port 1.                                                        | Input       | ANI0 to ANI7          |
|            |       | 8-bit input only port.                                         |             |                       |
| P20        | 1/0   | Port 2.                                                        | Input       | RxD00                 |
| P21        |       | 7-bit I/O port.                                                |             | TxD00                 |
| P22        |       | Input/output can be specified bit-wise.                        |             | RxD01                 |
| P23        |       | When used as an input port, an on-chip pull-up resistor can be |             | TxD01                 |
| P24        |       | connected by software.                                         |             | TI50/TO50             |
| P25        | _     |                                                                |             | TI51/TO51             |
| P26        |       |                                                                |             | TI52/TO52             |
| P30 to P37 | 1/0   | Port 3.                                                        | Input       | RTP0 to RTP7          |
|            |       | 8-bit I/O port.                                                |             |                       |
|            |       | Input/output can be specified bit-wise.                        |             |                       |
|            |       | When used as an input port, an on-chip pull-up resistor can be |             |                       |
|            |       | connected by software.                                         |             |                       |
| P40 to P47 | 1/0   | Port 4.                                                        | Input       | AD0 to AD7            |
|            |       | 8-bit I/O port.                                                |             |                       |
|            |       | Input/output can be specified bit-wise.                        |             |                       |
|            |       | When used as an input port, an on-chip pull-up resistor can be |             |                       |
|            |       | connected by software.                                         |             |                       |
| P50 to P57 | 1/0   | Port 5.                                                        | Input       | A8 to A15             |
|            |       | 8-bit I/O port.                                                |             |                       |
|            |       | Input/output can be specified bit-wise.                        |             |                       |
|            |       | LEDs can be driven directly.                                   |             |                       |
|            |       | When used as an input port, an on-chip pull-up resistor can be |             |                       |
|            |       | connected by software                                          |             |                       |
| P64        | 1/0   | Port 6.                                                        | Input       | RD                    |
| P65        | ]     | 4-bit I/O port.                                                |             | WB                    |
| P66        | ]     | Input/output can be specified bit-wise.                        |             | WAIT                  |
| P67        |       | When used as an input port, an on-chip pull-up resistor can be |             | ASTB                  |
|            |       | connected by software.                                         |             |                       |

📟 6427525 009941012T 📟

-

-----

#### 3.2 NON PORT PINS

| Pin Name     | 1/0    | Function                                                             | After Reset | Alternate<br>Function |
|--------------|--------|----------------------------------------------------------------------|-------------|-----------------------|
| INTPO        | Input  | External interrupt input that can specify the effective edge         | Input       | P00/TOFF7             |
| INTP1        | ]      | (rising edge, falling edge, or both rising and falling edges) can be | Input       | P01                   |
| INTP2        | ]      | specified.                                                           | Input       | P02                   |
| INTP3        | ]      |                                                                      | Input       | P03/ADTRG             |
| TI50         | Input  | External count clock input to timer (TM50).                          | Input       | P24/TO50              |
| TI51         | ]      | External count clock input to timer (TM51).                          | Input       | P25/TO51              |
| TI52         |        | External count clock input to timer (TM52).                          | Input       | P26/T052              |
| TO50         | Output | Timer (TM50) output.                                                 | Input       | P24/TI50              |
| TO51         |        | Timer (TM51) output.                                                 | Input       | P25/TI51              |
| TO52         | 1      | Timer (TM52) output.                                                 | Input       | P26/T152              |
| RTP0 to RTP7 | Output | Real-time output port that outputs pulses in synchronization with    | Input       | P30 to P37            |
|              |        | trigger signals outputs from the real-time pulse unit.               |             |                       |
| TxD00        | Output | Asynchronous serial interface serial data output.                    | Input       | P21                   |
| TxD01        | ]      |                                                                      | Input       | P23                   |
| RxD00        | Input  | Asynchronous serial interface serial data input.                     | Input       | P20                   |
| RxD01        |        |                                                                      | Input       | P22                   |
| ANI0 to ANI7 | Input  | A/D converter analog input.                                          | Input       | P10 to P17            |
| ADTRG        | Input  | External trigger signal input to the A/D converter.                  | Input       | P03/INTP3             |
| TO70 to TO75 | Output | Timer output for the 3-phase PWM inverter control.                   | Hi-Z        | _                     |
| TOFF7        | Input  | Timer output (TO70 to TO75) stop interrupt input.                    | Input       | P00/INTP0             |
| AD0 to AD7   | I/O    | Lower address/data bus when memory is expanded externally.           | Input       | P40 to P47            |
| A8 to A15    | Output | Upper address bus when memory is expanded externally.                | Input       | P50 to P57            |
| RD           | Output | Strobe signal output for external memory read operation.             | Input       | P64                   |
| WR           |        | Strobe signal output for external memory write operation.            | Input       | P65                   |
| WAIT         | Input  | Wait insertion when accessing external memory.                       | Input       | P66                   |
| ASTB         | Output | Strobe output that externally latches address information output     | Input       | P67                   |
|              |        | to ports 4 and 5 to access external memory.                          |             |                       |
| AVREF        | Input  | A/D converter reference voltage input.                               | -           | _                     |
| AVdd         | -      | A/D converter analog power supply. Connect to VDDO.                  | _           | _                     |
| AVss         | -      | A/D converter ground potential. Connect to Vsso.                     |             | _                     |
| RESET        | Input  | System reset input.                                                  | _           | _                     |
| X1           | Input  | Crystal connection for system clock oscillation.                     |             |                       |
| X2           | _      |                                                                      | -           |                       |
| VDDo         | -      | Positive power supply for ports.                                     | _           | _                     |
| Vsso         | -      | Ground potential for ports.                                          |             | _                     |
| VDD1         | -      | Positive power supply except for ports.                              | -           |                       |
| Vss1         | _      | Ground potential except for ports.                                   | _           |                       |
| TEST         | _      | Test mode set pin. Connect to Vsso directly.                         |             | _                     |

12

🔲 6427525 0099411 O66 페

## 3.3 RECOMMENDED CONNECTION OF UNUSED PINS

The recommended connections of unused pins are shown in Table 3-1.

| Pin Name             | I/O    | Recommended Connection of Unused Pins                |
|----------------------|--------|------------------------------------------------------|
| P00/INTP0/TOFF7      | 1/0    | Individually connect to Vsso via a resistor.         |
| P01/INTP1            |        |                                                      |
| P02/INTP2            |        |                                                      |
| P03/INTP3/ADTRG      |        |                                                      |
| P10/ANI0 to P17/ANI7 | Input  | Individually connect to VDD0 or Vss0 via a resistor. |
| P20/RxD00            | I/O    |                                                      |
| P21/TxD00            |        |                                                      |
| P22/RxD01            |        |                                                      |
| P23/TxD01            |        |                                                      |
| P24/TI50/TO50        |        |                                                      |
| P25/TI51/TO51        |        |                                                      |
| P26/TI52/TO52        |        |                                                      |
| P30/RTP0 to P37/RTP7 |        |                                                      |
| P40/AD0 to P47/AD7   |        |                                                      |
| P50/A8 to P57/A15    |        |                                                      |
| P64/RD               |        |                                                      |
| P65/WR               |        |                                                      |
| P66/WAIT             |        |                                                      |
| P67/ASTB             |        |                                                      |
| TO70 to TO75         | Output | Open                                                 |
| AVDD                 | _      | Connect to VDDo.                                     |
| AVREF                |        | Connect to Vsso.                                     |
| AVss                 |        |                                                      |
| TEST                 |        | Connect to Vsso directly.                            |

Table 3-1. Recommended Connection of Unused Pins

## 🖿 6427525 0099412 TT2 📰

-----

\_ .

\_\_\_\_

\_\_\_\_\_

#### 4. MEMORY SPACE

The memory map of the  $\mu$ PD780921, 780922, 780923, and 780924 is shown in Figure 4-1.





Note The internal ROM and internal high-speed RAM capacity differ depending on the product (see the table below).

| Product Name | Intenal ROM End Address | Internal High-Speed RAM<br>Start Address<br>mmmmH |
|--------------|-------------------------|---------------------------------------------------|
| μPD780921    | 1FFFH                   | FD00H                                             |
| μPD780922    | 3FFFH                   |                                                   |
| μPD780923    | 5FFFH                   | FB00H                                             |
| μPD780924    | 7FFFH                   |                                                   |

6427525 0099413 939 🖿

14

## 5. PERIPHERAL HARDWARE FUNCTION FEATURES

## 5.1 PORTS

Two kinds of I/O ports are provided.

| ÷ | 39 | '           |
|---|----|-------------|
|   |    | : 8<br>: 39 |

## Table 5-1. Functions of Ports

----

| Port Name | Pin Name   | Function                                                                                                                                                                   |
|-----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port 0    | P01 to P03 | I/O port. Input/output can be specified bit-wise.<br>When used as an input port, an on-chip pull-up resistor can be connected by software.                                 |
| Port 1    | P10 to P17 | Input only port.                                                                                                                                                           |
| Port 2    | P20 to P26 | I/O port. Input/output can be specified bit-wise.<br>When used as an input port, an on-chip pull-up resistor can be connected by software.                                 |
| Port 3    | P30 to P37 | I/O port. Input/output can be specified bit-wise.<br>When used as an input port, an on-chip pull-up resistor can be connected by software.                                 |
| Port 4    | P40 to P47 | I/O port. Input/output can be specified bit-wise.<br>When used as an input port, an on-chip pull-up resistor can be connected by software.                                 |
| Port 5    | P50 to P57 | I/O port. Input/output can be specified bit-wise.<br>When used as an input port, an on-chip pull-up resistor can be connected by software.<br>LEDs can be driven directly. |
| Port 6    | P64 to P67 | I/O port. Input/output can be specified bit-wise.<br>When used as an input port, an on-chip pull-up resistor can be connected by software.                                 |

## 📟 6427525 00994<u>1</u>4 875 📟

\_\_\_\_\_

------

15

## NEC

#### 5.2 CLOCK GENERATOR

A system clock generator is incorporated. The instruction exection time can be changed.

• 0.24 μs/0.48 μs/0.96 μs/1.9 μs/3.8 μs (@ 8.38-MHz operation with system clock)





16

17

## NEC

## 5.3 TIMER/EVENT COUNTERS

Five timer/event counter channels are incorporated.

- 8-bit timer/event counter : 3 channels
- 10-bit timer : 1 channel
- Watchdog timer : 1 channel

## Table 5-2. Types and Functions of Timer/Event Counters

|           |                        | 8-bit Timer/Event<br>Counter | 10-bit Timer | Watchdog Timer |
|-----------|------------------------|------------------------------|--------------|----------------|
| Туре      | Interval timer         | 3 channels                   | 1 channel    | 1 channel      |
|           | External event counter | 3 channels                   |              |                |
| Functions | Timer output           | 3 outputs                    | 6 outputs    |                |
|           | PWM output             | 3 outputs                    |              |                |
|           | Square wave output     | 3 outputs                    | _            |                |
|           | Interrupt request      | 3                            | 1            | 1              |





Note Count clock differs depending on the timer TM50 : fx/2, fx2<sup>3</sup>, fx2<sup>5</sup>, fx2<sup>7</sup>, fx2<sup>9</sup>, fx<sup>11</sup> TM51 : fx, fx/2, fx2<sup>2</sup>, fx2<sup>3</sup>, fx2<sup>4</sup>, fx2<sup>5</sup> TM52 : fx2<sup>4</sup>, fx2<sup>5</sup>, fx2<sup>6</sup>, fx2<sup>7</sup>, fx2<sup>8</sup>, fx2<sup>9</sup>

\_\_\_\_\_

Remark n = 0 to 2

■ 6427525 00994<u>16</u> 648 ■



Figure 5-3. 10-bit Timer Block Diagram







## 5.4 REAL-TIME OUTPUT PORT

The real-time output port outputs data stored in buffers in synchronization with match interrupts of 8-bit timer/event counters (TM50 and TM52) or external interrupts, enabling to output pulses without jitter.

Therefore, the real-time output method is suited for applications which output given patterns at set intervals.





#### 5.5 A/D CONVERTER

NEC

Eight 8-bit resolution A/D converter channels are incorporated. A/D conversion by the following two methods.

- · Hardware start
- Software start







#### 5.6 SERIAL INTERFACE

Two independent serial interface channels (UART00 and UART01) are incorporated.

Each serial interface incorporates a baud-rate generator. Therefore, it is possible to set a serial transfer rate that is independent of the operating clock frequency.

The serial transfer rate can be set from 75 to 76800 bps (@ fx = 8.38-MHz operation) by setting the mode register.



#### Table 5-7. Serial Interface Block Diagram

**Remark** n = 0, 1

#### 6427525 0099420 079 🎟

## 6. INTERRUPT FUNCTIONS

NEC

There are 18 interrupt functions of three different kinds as shown below.

Non-maskable interrupt : 1
 Maskable interrupt : 16
 Software interrupt : 1

|                | Default         |         | Interrupt Source                          | Internal/ | Vector Table | Basic                                  |  |
|----------------|-----------------|---------|-------------------------------------------|-----------|--------------|----------------------------------------|--|
| Interrupt Type | Priority Note 1 | Name    | Trigger                                   | External  | Address      | Configuratin<br>Type <sup>Note 2</sup> |  |
| Non-maskable   | _               | INTWDT  | Watchdog timer overflow                   | Internal  | 0004H        | (A)                                    |  |
|                |                 |         | (when non-maskable interrupt is selected) |           |              |                                        |  |
| Maskable       | 0               | INTWDT  | Watchdog timer overflow                   |           |              | (B)                                    |  |
| Ĺ              |                 |         | (when interval timer is selected)         |           |              |                                        |  |
|                | 1               | INTP0   | Pin input edge detection                  | External  | 0006H        | (C)                                    |  |
|                | 2               | INTP1   |                                           |           | 0008H        |                                        |  |
|                | 3               | INTP2   |                                           |           | 000AH        |                                        |  |
|                | 4               | INTP3   |                                           |           | 000CH        |                                        |  |
| L              | 5               | INTTM7  | TM7 under flow                            | Internal  | 000EH        | (B)                                    |  |
|                | 6               | INTSERO | UART00 receive error generation           |           | 0010H        |                                        |  |
|                | 7               | INTSR0  | UART00 receive termination                |           | 0012H        |                                        |  |
|                | 8               | INTSTO  | UART00 transmit termination               |           | 0014H        |                                        |  |
|                | 9               | INTSER1 | UART01 receive error generation           |           | 0016H        |                                        |  |
|                | 10              | INTSR1  | UART01 receive termination                |           | 0018H        |                                        |  |
|                | 11              | INTST1  | UART01 transmit termination               |           | 001AH        | `                                      |  |
|                | 12              | INTTM50 | TM50 and CR50 match signal generation     |           | 001CH        |                                        |  |
|                | 13              | INTTM51 | TM51 and CR51 match signal generation     |           | 001EH        |                                        |  |
|                | 14              | INTTM52 | TM52 and CR52 match signal generation     |           | 0020H        |                                        |  |
|                | 15              | INTAD0  | A/D conversion termination                |           | 0022H        |                                        |  |
| Software       | _               | BRK     | BRK instruction execution                 | _         | 003EH        | (D)                                    |  |

Notes 1. The default priority is the priority applicable when more than one maskable interrupt is generated. 0 is the highest priority and 15, the lowest.

🖿 6427525 0099421 TO5 🛲

2. Basic configuration types (A) to (D) correspond to (A) to (D) on the next page.

22

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

#### (A) Internal non-maskable interrupt



## (B) Internal maskable interrupt



#### (C) External Maskable Interrupt



#### 💻 6427525 0099422 94**] 📖**

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

## (D) Software Interrupt



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

## 🖬 6427525 0099423 888 🎟

## 7. EXTERNAL DEVICE EXPANSION FUNCTION

The external device expansion function is used to connect external devices to areas other than the internal ROM, RAM and SFR.

Ports 4 to 6 are used for connection with external devices.

## 8. STANDBY FUNCTIONS

There are the following two standby functions to reduce the current consumption.

- HALT mode : The CPU operating clock is stopped. The average current consumption can be reduced by intermittent operation in combination with the normal operating mode.
- STOP mode : The system clock oscillation is stopped. The whole operation by the system clock is stopped, so that the system operates with ultra-low power dissipation.



#### 9. RESET FUNCTIONS

There are the following two reset methods.

- External reset by RESET input.
- Internal reset by watchdog timer runaway time detection

| 6427525 | 0099424 | 714 🔳 |
|---------|---------|-------|
|---------|---------|-------|

25

## **10. INSTRUCTION SET**

#### (1) 8-bit instructions

MOV, XCH, ADD, ADDC, SUB, SUBC, AND, OR, XOR, CMP, MULU, DIVUW, INC, DEC, ROR, ROL, RORC, ROLC, ROR4, ROL4, PUSH, POP, DBNZ

|                            |              | T    | 1      | T   | 1     | T          | 1   | T      | <b></b>    | 1                   | T    |      |       |
|----------------------------|--------------|------|--------|-----|-------|------------|-----|--------|------------|---------------------|------|------|-------|
| 2nd Operand<br>1st Operand | \ #byte      | A    | r Note | sfr | saddr | laddr16    | PSW | [DE]   | (HL)       | [HL+byte]<br>[HL+B] |      | 1    | None  |
|                            |              |      |        |     |       |            |     |        | ļ          | [HL+C]              |      |      |       |
| A                          | ADD          | }    | MOV    | MOV | MOV   | MOV        | MOV | MOV    | MOV        | MOV                 |      | ROR  |       |
|                            | ADDC         |      | хсн    | ХСН | хсн   | хсн        | 1   | ХСН    | ХСН        | ХСН                 |      | ROL  |       |
|                            | SUB          |      | ADD    |     | ADD   | ADD        |     |        | ADD        | ADD                 |      | RORC |       |
|                            | SUBC         |      | ADDC   |     | ADDC  | ADDC       |     |        | ADDC       | ADDC                |      | ROLC |       |
|                            | AND          | 1    | SUB    |     | SUB   | SUB        |     | -      | SUB        | SUB                 |      |      |       |
|                            | OR           |      | SUBC   |     | SUBC  | SUBC       |     | 1      | SUBC       | SUBC                |      |      |       |
|                            | XOR          | 1    | AND    |     | AND   | AND        |     |        | AND        | AND                 |      | 1    |       |
|                            | CMP          |      | OR     |     | OR    | OR         |     |        | OR         | OR                  |      |      |       |
|                            |              |      | XOR    |     | XOR   | 1          |     |        | 1          |                     |      |      |       |
|                            |              |      | CMP    |     | CMP   | XOR<br>CMP |     |        | XOR<br>CMP | XOR<br>CMP          |      |      |       |
| r                          | MOV          | MOV  |        |     |       |            |     |        | CIVIF      |                     |      |      | +     |
| -                          |              | ADD  |        |     |       |            |     |        |            |                     |      |      | INC   |
|                            |              |      |        |     |       |            |     |        |            |                     |      |      | DEC   |
|                            |              | ADDC |        |     |       |            |     |        |            |                     |      |      |       |
|                            |              | SUB  |        | i   |       |            |     |        |            |                     |      |      |       |
|                            |              | SUBC |        |     |       |            |     |        |            |                     |      |      |       |
|                            |              | AND  |        |     |       |            |     |        |            |                     |      |      |       |
|                            |              | OR   |        |     |       |            |     |        |            |                     |      |      |       |
|                            |              | XOR  |        |     |       |            |     |        |            |                     |      |      |       |
|                            |              | CMP  |        |     |       |            |     |        |            |                     |      |      |       |
| B, C                       |              |      |        |     |       |            |     |        |            |                     | DBNZ |      |       |
| str                        | MOV          | MOV  |        |     |       |            |     |        |            |                     |      |      |       |
| saddr                      | MOV          | MOV  |        |     |       |            |     |        |            |                     | DBNZ |      | INC   |
|                            | ADD          |      |        |     |       |            |     |        |            |                     |      |      | DEC   |
|                            | ADDC         |      |        |     |       |            | 1   |        |            |                     |      |      |       |
|                            | SUB          |      |        |     |       |            |     |        |            |                     |      |      |       |
|                            | SUBC         |      |        |     |       |            |     |        | ĺ          |                     |      |      |       |
|                            | AND          |      |        |     |       | 1          |     |        | [          |                     |      |      |       |
|                            | OR           |      |        |     |       | l l        |     |        |            |                     |      |      |       |
|                            | XOR          |      |        |     |       |            |     |        |            |                     |      |      |       |
|                            | CMP          |      | [      |     |       |            |     |        |            |                     |      |      |       |
| laddr16                    |              | MOV  |        |     |       |            |     |        |            |                     |      |      |       |
| PSW                        | MOV          | MOV  |        |     |       |            |     |        |            |                     |      |      | PUSH  |
|                            |              |      |        |     |       |            |     | i<br>I |            |                     | -    |      | POP   |
| [DE]                       |              | MOV  |        |     |       |            |     |        |            |                     |      |      |       |
| [HL]                       |              | MOV  |        |     |       |            |     |        |            |                     |      |      | ROR4  |
| [HL+byte]                  | ├── ┤        | MOV  |        |     |       |            |     |        |            |                     |      |      | ROL4  |
| [HL+B]                     |              |      | [      |     |       |            | i i |        |            |                     |      |      |       |
| [HL+C]                     |              |      | 1      |     |       |            |     |        |            |                     |      |      |       |
| X                          | <u>├</u> ─── | -    |        |     |       |            |     |        |            | — <del> </del>      |      |      |       |
| <u>с</u>                   | ┟╼╴╶┧        |      |        |     |       |            |     |        |            |                     |      |      | MULU  |
|                            | r=A          |      |        |     |       |            |     |        |            |                     |      |      | DIVUW |

Note Except r=A

26

🖬 6427525 0099425 650 🔳

-----

#### (2) 16-bit instructions

MOVW, XCHW, ADDW, SUBW, CMPW, PUSH, POP, INCW, DECW

| 2nd Operand<br>1st Operand | #byte | AX                   | rp <sup>Note</sup> | strp | saddrp | laddr16                                | SP   | None                    |
|----------------------------|-------|----------------------|--------------------|------|--------|----------------------------------------|------|-------------------------|
| AX                         | ADDW  |                      | MOVW               | MOVW | MOVW   | MOVW                                   | MOVW |                         |
|                            | SUBW  |                      | хснw               |      |        |                                        |      |                         |
|                            | CMPW  |                      |                    |      |        |                                        |      |                         |
| rp                         | MOVW  | MOVW <sup>Note</sup> |                    |      |        |                                        |      | INCW, DECW<br>PUSH, POP |
| strp                       | MOVW  | MOVW                 |                    |      |        |                                        |      |                         |
| saddrp                     | MOVW  | MOVW                 |                    |      |        |                                        |      |                         |
| laddr16                    |       | MOVW                 |                    |      |        |                                        | 1    |                         |
| SP                         | MOVW  | MOVW                 |                    |      |        | ······································ | 1    |                         |

Note Only when rp = BC, DE, HL.

## (3) Bit manipulation instructions

MOV1, AND1, OR1, XOR1, SET1, CLR1, NOT1, BT, BF, BTCLR

| 2nd Operand | A L 1                       |                             |                             |                             |                             |      |                   |                      |
|-------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|------|-------------------|----------------------|
| 1st Operand | A.bit                       | sfr.bit                     | saddr.bit                   | PWS.bit                     | [HL].bit                    | CY   | \$addr16          | None                 |
| A.bit       |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| sfr.bit     |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| saddr.bit   |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| PSW.bit     |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| [HL].bit    |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| CY          | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 |      |                   | SET1<br>CLR1<br>NOT1 |

## 🖬 6427525 0099426 597 🛤

Powered by ICminer.com Electronic-Library Service CopyRight 2003

\_\_\_\_\_

## (4) Call instruction/branch instructions

CALL, CALLF, CALLT, BR, BC, BNC, BZ, BNZ, BT, BF, BTCLR, DBNZ

| 2nd Operand<br>1st Operand | AX | laddr16  | laddr11 | [addr5] | \$addr16                |
|----------------------------|----|----------|---------|---------|-------------------------|
| Basic instruction          | BR | CALL, BR | CALLF   | CALLT   | BR, BC, BNC,<br>BZ, BNZ |
| Compound instruction       |    |          |         |         | BT,BF,BTCLR,<br>DBNZ    |

## (5) Other Instructions

ADJBA, ADJBS, BRK, RET, RETI, RETB, SEL, NOP, EI, DI, HALT, STOP

28

\_ \_ \_ \_

## **11. PACKAGE DRAWINGS**

NEC

## 64 PIN PLASTIC SHRINK DIP (750 mil)





σΙ

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.

NM

 $\oplus$ 

D

| ITEM | MILLIMETERS  | INCHES       |
|------|--------------|--------------|
| Α    | 58.68 MAX.   | 2.311 MAX.   |
| В    | 1.78 MAX.    | 0.070 MAX.   |
| С    | 1.778 (T.P.) | 0.070 (T.P.) |
| D    | 0.50±0.10    | 0.020+0.004  |
| F    | 0.9 MIN.     | 0.035 MIN.   |
| G    | 3.2±0.3      | 0.126±0.012  |
| H    | 0.51 MIN.    | 0.020 MIN.   |
| 1    | 4.31 MAX.    | 0.170 MAX.   |
| J    | 5.08 MAX.    | 0.200 MAX.   |
| К    | 19.05 (T.P.) | 0.750 (T.P.) |
| L    | 17.0         | 0.669        |
| м    | 0.25+0.10    | 0.010+0.004  |
| N    | 0.17         | 0.007        |
| R    | 0~15°        | 0~15°        |

М

СВ

P64C-70-750A,C-1



## 🖬 6427525 0099428 36T 🎟

## 64 PIN PLASTIC QFP (□14)



detail of lead end



#### NOTE

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

| ITEM |             | P64GC-80-AB8-3 |
|------|-------------|----------------|
| 1151 | MILLIMETERS | INCHES         |
| A    | 17.6±0.4    | 0.693±0.016    |
| В    | 14.0±0.2    | 0.551+0.009    |
| С    | 14.0±0.2    | 0.551+0.009    |
| D    | 17.6±0.4    | 0.693±0.016    |
| F    | 1.0         | 0.039          |
| G    | 1.0         | 0.039          |
| н    | 0.35±0.10   | 0.014+0.004    |
| 1    | 0.15        | 0.006          |
| J    | 0.8 (T.P.)  | 0.031 (T.P.)   |
| κ    | 1.8±0.2     | 0.071±0.008    |
| L    | 0.8±0.2     | 0.031+0.009    |
| м    | 0.15+0.10   | 0.006+0.004    |
| N    | 0.10        | 0.004          |
| Р    | 2.55        | 0.100          |
| ۵    | 0.1±0.1     | 0.004±0.004    |
| S    | 2.85 MAX.   | 0.112 MAX.     |

#### 30

🛚 6427525 0099429 2T6 🖿

## **APPENDIX A. DEVELOPMENT TOOLS**

The following development tools are available for system development using the  $\mu$ PD780924 subseries.

## Language Processing Software

| RA78K/0 Notes 1, 2, 3, 4     | 78K/0 series common assembler package              | ····· |
|------------------------------|----------------------------------------------------|-------|
| CC78K/0 Notes 1, 2, 3, 4     | 78K/0 series common C compiler package             |       |
| DF780964 Notes 1, 2, 3, 4, 8 | μPD780924 subseries common device file             | ·     |
| CC78K/0-L Notes 1, 2, 3, 4   | 78K/0 series common C compiler library source file |       |

## Flash Memory Writing Tools

| Flashpro                                                                                                 | Dedicated flash memory writer. The Flashpro is a product of Naitou Densei Machida Seisakusho Co., Ltd. |
|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|
| PA-FLASH64CW<br>(temporary name) <sup>Note 8</sup><br>PA-FLASH64GC<br>(temporary name) <sup>Note 8</sup> | Adapter to write data to the flash memory                                                              |

## **Debugging Tools**

| IE-780000-SL                 | 75XL, 78K/0S, 78K/0, and 78K/IV series common in-circuit emulator                            |
|------------------------------|----------------------------------------------------------------------------------------------|
| (temporary name) Note 8      |                                                                                              |
| IE-78K0-SL-EM                | 78K/0 series common CPU core board                                                           |
| (temporary name) Note 8      |                                                                                              |
| IE-780964-SL-EM1             | Probe board to emulate µPD780924 subseries products                                          |
| (temporary name) Note 8      |                                                                                              |
| EP-64CW-SL                   | Emulation probe for 64-pin plastic shrink DIP (CW type)                                      |
| (temporary name) Note 8      |                                                                                              |
| EP-64GC-SL                   | Emulation probe for 64-pin plastic QFP (GC-AB8 type)                                         |
| (temporary name) Note 8      |                                                                                              |
| EV-9200GC-64                 | Socket to be mounted on target system board created for the 64-pin plastic QFP (GC-AB8 type) |
| SM78K0 Notes 5, 6, 7         | 78K/0 series common system simulator                                                         |
| 1D78K0 Notes 4, 5, 6, 7      | IE-780000-SL integrated debugger                                                             |
| DF780964 Notes 4, 5, 6, 7, 8 | Device file common to µPD780924 subseries                                                    |

#### Real-Time OSs

| RX78K/0 Notes 1, 2, 3, 4 | 78K/0 series real-time OS |
|--------------------------|---------------------------|
| MX78K0 Notes 1, 2, 3, 4  | 78K/0 series OS           |

## Fuzzy Inference Development Support Systems

| FE9000 Note 1/FE9200 Note 5 | Fuzzy knowledge data creation tool |
|-----------------------------|------------------------------------|
| FT9080 Note 1/FT9085 Note 2 | Translator                         |
| FI78K0 Notes 1, 2           | Fuzzy inference module             |
| FD78K0 Notes 1, 2           | Fuzzy inference debugger           |

Notes 1. PC-9800 series (MS-DOS<sup>™</sup>) based

- 2. IBM PC/AT<sup>™</sup> and compatibles (PC DOS<sup>™</sup>/IBM DOS<sup>™</sup>/MS-DOS) based
- 3. HP9000 series 300<sup>™</sup> (HP-UX<sup>™</sup>) based
- 4. HP9000 series 700<sup>™</sup> (HP-UX) based, SPARCstation<sup>™</sup> (SunOS<sup>™</sup>) based, EWS4800 series (EWS-UX/V) based
- 5. PC-9800 series (MS-DOS + Windows™) based
- 6. IBM PC/AT and compatibles (PC DOS/IBM DOS/MS-DOS + Windows) based
- 7. NEWS<sup>™</sup> (NEWS-OS<sup>™</sup>) based
- 8. Under development

Remark RA78K/0, CC78K/0, SM78K0, ID78K0, and RX78K/0 are used in combination with DF780964.

#### 🖬 6427525 0099431 954 📰

## APPENDIX B. RELATED DOCUMENTS

#### **Device Related Documents**

| Document Name                                                     | Docume<br>English<br>Planned<br>This manual<br>Planned<br>—<br>IEU-1372<br>— | nt No.   |
|-------------------------------------------------------------------|------------------------------------------------------------------------------|----------|
|                                                                   | English                                                                      | Japanese |
| μPD780924 Subseries User's Manual                                 | Planned                                                                      | Planned  |
| μPD780921, 780922, 780923, 780924 Preliminary Product Information | This manual                                                                  | U11804J  |
| µPD78F0924 Preliminary Product Information                        | Planned                                                                      | Planned  |
| µPD780924 Subseries Special Function Register Table               | _                                                                            | Planned  |
| 78K/0 Series User's Manual Instructions                           | IEU-1372                                                                     | IEU-849  |
| 78K/0 Series Instruction Table                                    | _                                                                            | U10903J  |
| 78K/0 Series Instruction Set                                      |                                                                              | U10904J  |

## **Development Tool Documents (User's Manuals)**

| Document Name                                |                                                     | Document No. |          |
|----------------------------------------------|-----------------------------------------------------|--------------|----------|
|                                              |                                                     | English      | Japanese |
| RA78K Series Assembler Package               | Operation                                           | EEU-1399     | EEU-809  |
|                                              | Language                                            | EEU-1404     | EEU-815  |
| RA78K Series Structured Assembler Preprocess | sor                                                 | EEU-1402     | EEU-817  |
| CC78K Series C Compiler                      | Operation                                           | EEU-1280     | EEU-656  |
|                                              | Language                                            | EEU-1284     | EEU-655  |
| CC 78K0 C Compiler                           | Operation                                           | U11517E      | U11517J  |
|                                              | Language                                            | U11518E      | U11518J  |
| CC78K/0 C Compiler Application Note          | Programming Know-how                                | EEA-1208     | EEA-618  |
| CC78K Series Library Source File             |                                                     | _            | EEU-777  |
| IE-780000-SL                                 |                                                     | Planned      | Planned  |
| IE-78K0-SL-EM                                |                                                     | Planned      | Planned  |
| IE-780924-SL-EM1                             |                                                     | Planned      | Planned  |
| EP-64CW-SL                                   |                                                     | Planned      | Planned  |
| EP-64GC-SL                                   |                                                     | Planned      | Planned  |
| SM78K0 System Simulator Windows-based        | Reference                                           | U10181E      | U10181J  |
| SM78K Series System Simulator                | External parts user open<br>interface specification | U10092E      | U10092J  |
| ID78K0 Integrated Debugger EWS-based         | Reference                                           | U11151E      | U11151J  |
| ID78K0 Integrated Debugger PC-based          | Reference                                           | U11539E      | U11539J  |
| ID78K0 Integrated Debugger Windows-based     | Guide                                               | U11649E      | U11649J  |

Caution The above related documents are subject to change without notice. Be sure to use the latest documents when starting design.



- ---- -- --

Powered by ICminer.com Electronic-Library Service CopyRight 2003

\_\_\_\_\_

## Embedded Software Documents (User's Manuals)

| Document Name                                          |                    | Document No. |          |
|--------------------------------------------------------|--------------------|--------------|----------|
|                                                        | nthame             | English      | Japanese |
| 78K/0 Series Real-Time OS                              | Basics             | _            | U11537J  |
|                                                        | Installation       | -            | U11536J  |
|                                                        | Technical          | -            | U11538J  |
| 78K/0 Series OS MX78K0                                 | Basics             | EEU-1532     | EEU-5010 |
| Fuzzy Knowledge Data Creation Tool                     |                    | EEU-1438     | EEU-829  |
| 78K/0, 78K/II, 87AD Series                             |                    | EEU-1444     | EEU-862  |
| Fuzzy Inference Development Support S                  | System Translator  |              |          |
| 78K/0 Series Fuzzy Inference Development Suport System |                    | EEU-1441     | EEU-858  |
| Fuzzy Inference Module                                 |                    |              |          |
| 78K/0 Series Fuzzy Inference Developm                  | ent Support System | EEU-1458     | EEU-921  |
| Fuzzy Inference Debugger                               |                    |              |          |

#### Other Documents

| Document Name                                               | Docum    | ent No.  |
|-------------------------------------------------------------|----------|----------|
|                                                             | English  | Japanese |
| IC Package Manual                                           | C10943X  |          |
| Semiconductor Device Mounting Technology Manual             | C10535E  | C10535J  |
| Quality Grades on NEC Semiconductor Devices                 | C11531E  | C11531J  |
| NEC Semiconductor Device Reliability/Quality Control System | C10983E  | C10983J  |
| Electrostatic Discharge (ESD) Test                          | IEI-1201 | MEM-539  |
| Guide to Quality Assurance for Semiconductor Devices        | MEI-1202 | MEI-603  |
| Microcomputer Product Series Guide                          | _        | MEI-604  |

Caution The above related documents are subject to change without notice. Be sure to use the latest documents when starting design.

34

6427525 0099433 727 🖿

[MEMO]

## PAGE(S) INTENTIONALLY BLANK

🖬 6427525 0099434 663 **5** 

35

Powered by ICminer.com Electronic-Library Service CopyRight 2003

\_\_\_\_

[MEMO]

## PAGE(S) INTENTIONALLY BLANK



🔲 6427525 0099435 STT 페

#### [MEMO]

The following supersedes any statement which may be found elsewhere in this document purporting to address the subjects of quality, reliability or suitability of any devices listed in this document for applications other than as noted.

No part of this document may be copied or reproduced in any form or by any means without prior written consent of NEC Electronics Inc. (NECEL). The information in this document is subject to change without notice. ALL DEVICES SOLD BY NECEL ARE COVERED BY THE PROVISIONS APPEARING IN NECEL TERMS AND CONDITIONS OF SALE ONLY, INCLUDING THE LIMITATION OF LIABILITY, WARRANTY, AND PATENT PROVISIONS. NECEL makes no warranty, express, statutory, implied or by description, regarding information set forth herein or regarding the freedom of the described devices from patent infringement. NECEL assumes no responsibility for any errors that may appear in this document. NECEL makes no commitments to update or to keep current information contained in this document. The devices listed in this document are not suitable for use in applications such as, but not limited to, aircraft control systems, aerospace equipment, submarine cables, nuclear reactor control systems and life support systems. "Standard" quality grade devices are recommended for computers, office equipment, communication equipment, test and measurement equipment, traffic control systems, anti-disaster and anti-systems, it is recommended that the customer contact the responsible NECEL salesperson to determine the reliability requirements is such application and any cost adder. NECEL does not recommend or approve use of any of its products in life support devices or sys, or in any application where failure could result in injury or death. If customers wish to use NECEL devices in applications not intendeo NECEL, customer must contact the responsible NECEL sales people to determine the reliability requirements is or in any application where failure could result is injury or death. If customers wish to use NECEL devices in applications not intendeo

For literature, call toll-free 7 a.m. to 6 p.m. Pacific time: 1-800-366-9782 or FAX your request to: 1-800-729-9288

🛲 6427525 0099436 436 🎟

### -NOTES FOR CMOS DEVICES-

# **① PRECAUTION AGAINST ESD FOR SEMICONDUCTORS**

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

### ② HANDLING OF UNUSED INPUT PINS FOR CMOS

Note: No connection for CMOS device inputs can be cause of malfunction. If no connection is provided to the input pins, it is possible that an internal input level may be generated due to noise, etc., hence causing malfunction. CMOS 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.

38

NEC

🖿 6427525 0099437 372 📰

# **Regional Information**

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

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

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

NEC Electronics Inc. (U.S.) Mountain View, California Tel: 800-366-9782 Fax: 800-729-9288

NEC Electronics (Germany) GmbH Duesseldorf, Germany Tel: 0211-65 03 02 Fax: 0211-65 03 490

NEC Electronics (UK) Ltd. Milton Keynes, UK

Tel: 01908-691-133 Fax: 01908-670-290

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

**NEC Electronics (France) S.A.** France Tel: 01-30-67 58 00 Fax: 01-30-67 58 99

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

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

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

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

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

NEC do Brasil S.A.

Sao Paulo-SP, Brasil Tel: 011-889-1680 Fax: 011-889-1689

**J96.** 3

•••• 6427525 0099438 209 **•••** 

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

NEC

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

FIP and IEBus are trademarks of NEC Corporation. MS-DOS and Windows are trademarks of Microsoft Corporation. IBM DOS, PC/AT, and PC DOS are trademarks of International Business Machines Corporation. HP9000 Series 300, HP9000 series 700, and HP-UX are trademarks of Hewlett-Packard Company. SPARCstation is a trademark of SPARC International, Inc. SunOS is a trademark of Sun Microsystems, Inc. NEWS and NEWS-OS are trademarks of Sony Corporation.

6427525 0099439 145 🔳



# μ**PD780924, 780964 SUBSERIES**

# **8-BIT SINGLE-CHIP MICROCONTROLLER**

# (PRELIMINARY)

μPD780921 μPD780922 μPD780923 μPD780924 μPD78F0924

μΡD780961 μΡD780962 μΡD780963 μΡD780964 μΡD78F0964

NF

© NEC Corporation 1997



Document No. U12071EJ1V0UM00 (1st edition) Date Published January 1997 N Printed in Japan

#### **① PRECAUTION AGAINST ESD FOR SEMICONDUCTORS**

#### Note:

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

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

#### Note:

No connection for CMOS device inputs can be cause of malfunction. If no connection is provided to the input pins, it is possible that an internal input level may be generated due to noise, etc., hence causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using a pull-up or pull-down circuitry. Each unused pin should be connected to Voo 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.

The following supersedes any statement which may be found elsewhere in this document purporting to address the subjects of quality, reliability or suitability of any devices listed in this document for applications other than as noted.

No part of this document may be copied or reproduced in any form or by any means without prior written consent of NEC Electronics Inc. (NECEL). The information in this document is subject to change without notice. ALL DEVICES SOLD BY NECEL ARE COVERED BY THE PROVISIONS APPEARING IN NECEL TERMS AND CONDITIONS OF SALE ONLY, INCLUDING THE LIMITATION OF LIABILITY, WARRANTY, AND PATENT PROVISIONS. NECEL makes no warranty, express, statutory, implied or by description, regarding information set forth herein or regarding the freedom of the described devices from patent infringement. NECEL assumes no responsibility for any errors that may appear in this document. NECEL makes no commitments to update or to keep current information contained in this document. The devices listed in this document are not suitable for use in applications such as, but not limited to, aircraft control systems, aerospace equipment, submarine cables, nuclear reactor control systems and life support systems. "Standard" quality grade devices are recommended for computers, office equipment, communication equipment, test and measurement equipment, traffic control systems, anti-clisaster and anti-crime systems, it is recommended that the customer contact the responsible NECEL salesperson to determine the reliability requirements for any such application and any cost adder. NECEL does not recommend or approve use of any of its products in life support devices or systems or in any application where failure could result in injury or death. If customers wish to use NECEL devices in applications not intended by NECEL, customer must contact the responsible NECEL's willingness to support a given application.

For literature, call toll-free 7 a.m. to 6 p.m. Pacific time: 1-800-366-9782

or FAX your request to: 1-800-729-9288



FIP and IEBus are trademarks of NEC Corporation. MS-DOS and Windows are trademarks of Microsoft Corporation. IBM DOS, PC/AT, and PC DOS are trademarks of International Business Machines Corporation. HP9000 series 300, HP9000 series 700, and HP-UX are trademarks of Hewlett-Packard Co. SPARCstation is a trademark of SPARC International, Inc. SunOS is a trademark of Sun Microsystems, Inc. Ethernet is a trademark of Xerox Corporation. NEWS and NEWS-OS are trademarks of Sony Corporation. OSF/Motif is a trademark of Open Software Foundation, Inc. TRON is an abbreviation of The Realtime Operating system Nucleus. ITRON is an abbreviation of Industrial TRON.

🖬 6427525 0099442 73T 🎟

-

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

| License not needed                           | : μPD78F0924, 78F0964               |
|----------------------------------------------|-------------------------------------|
| The customer must judge the need for license | : μPD780921, 780922, 780923, 780924 |
|                                              | μPD780961, 780962, 780963, 780964   |

The application circuits and their parameters are for reference only and are not intended for use in actual design-ins.

The information contained in this document is being issued in advance of the production cycle for the device. The parameters for the device may change before final production or NEC Corporation, at its own discretion, may withdraw the device prior to its production.

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.



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

🖬 6427525 0099444 502 🖿

F

#### INTRODUCTION

| Readers                 | This manual is intended for u                     | ser engineers who understand the functions of the           |
|-------------------------|---------------------------------------------------|-------------------------------------------------------------|
|                         | $\mu$ PD780924 and $\mu$ PD780964 st              | ubseries and wish to design and develop its application     |
|                         | systems and programs.                             |                                                             |
|                         | Target products are as follows                    | s:                                                          |
|                         |                                                   | -                                                           |
|                         | <ul> <li>μPD780924 subseries:</li> </ul>          | μPD780921, 780922, 780923, 780924, 78F0924                  |
|                         | <ul> <li>μPD780964 subseries:</li> </ul>          | μPD780961, 780962, 780963, 780964, 78F0964                  |
|                         | pi Drocovy Subseries.                             | <i>μι 0700301, 700302, 700303, 700304, 70</i> -0364         |
| Purpose                 | This manual is designed to do                     |                                                             |
|                         |                                                   | sepen your understanding of the following functions         |
|                         | using the following organization                  | on.                                                         |
| Organization            |                                                   |                                                             |
| or guinzation           |                                                   | or the $\mu$ PD780924 and $\mu$ PD780964 subseries: this    |
|                         | manual and instruction Manua                      | al (common to the 78K/0 series).                            |
|                         |                                                   |                                                             |
|                         | μPD780924, 780964                                 | 78K/0 series                                                |
|                         | subseries User's Manual                           | User's Manual Instruction                                   |
|                         | <ul> <li>Pin functions</li> </ul>                 | CPU function                                                |
|                         | <ul> <li>Internal block functions</li> </ul>      | <ul> <li>Instruction set</li> </ul>                         |
|                         | <ul> <li>Interrupt</li> </ul>                     | <ul> <li>Instruction description</li> </ul>                 |
|                         | <ul> <li>Other internal peripheral fur</li> </ul> | nctions                                                     |
|                         |                                                   |                                                             |
| How to Read This Manual | It is assumed that the readers                    | of this manual have general knowledge on electric           |
|                         | engineering, logic circuits, and                  | -                                                           |
|                         |                                                   |                                                             |
|                         | To understand the overall fur                     | nctions of the $\mu$ PD780924 and $\mu$ PD780964 subseries  |
|                         |                                                   | order of the TABLE OF CONTENTS.                             |
|                         | How to read register format                       |                                                             |
|                         | -                                                 | number is encircled is reserved for the RA78K/0 and         |
|                         |                                                   | /0 by the header file sfrbit.h.                             |
|                         |                                                   |                                                             |
|                         | → Refer to APPENDIX C F                           | ons of a register whose register name is known              |
|                         |                                                   |                                                             |
|                         |                                                   | truction functions of the $\mu$ PD780924 and $\mu$ PD780964 |
|                         | subseries                                         |                                                             |
|                         |                                                   | ser's Manual - Instruction (IEU-1372) separately            |
|                         | available.                                        |                                                             |
|                         |                                                   |                                                             |
|                         |                                                   | _                                                           |
|                         |                                                   | F                                                           |
|                         |                                                   |                                                             |
|                         |                                                   |                                                             |
|                         |                                                   |                                                             |
|                         |                                                   |                                                             |
|                         |                                                   |                                                             |
|                         |                                                   |                                                             |
|                         |                                                   |                                                             |
|                         |                                                   |                                                             |

**6**427525 0099445 449 **6** 

-----

- · ·

Legend

| Data significance        | : | Left: higher digit, right: lower digit |
|--------------------------|---|----------------------------------------|
| Active low               | : | XXX (top bar over pin or signal name)  |
| Note                     | : | Footnote                               |
| Caution                  | : | Important information                  |
| Remark                   | : | Supplement                             |
| Numerical representation | : | Binary XXXX or XXXXB                   |
|                          |   | Decimal XXXX                           |
|                          |   | Hexadecimal XXXXH                      |

#### **Related Documents**

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

#### • Device-related documents

| Document Name                                                     | Document Number         |                         |  |
|-------------------------------------------------------------------|-------------------------|-------------------------|--|
|                                                                   | Japanese                | English                 |  |
| µPD780921, 780922, 780923, 780924 Preliminary Product Information | U11804J                 | Planned to be published |  |
| μPD780961, 780962, 780963, 780964 Preliminary Product Information | U11879J                 | Planned to be published |  |
| μPD78F0924 Preliminary Product Information                        | U11930J                 | Planned to be published |  |
| μPD78F0964 Preliminary Product Information                        | U11956J                 | Planned to be published |  |
| μPD780924, 780964 Subseries User's Manual                         | U12071J                 | This manual             |  |
| 78K/0 Series User's Manual - Instruction                          | IEU-849                 | IEU-1372                |  |
| 78K/0 Series Instruction List                                     | U10903J                 | -                       |  |
| 78K/0 Series Instruction Set                                      | U10904J                 |                         |  |
| μPD780924, 780964 Subseries Special Function Register List        | Planned to be published |                         |  |

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



#### 🖬 6427525 0099446 385 📰

### · Development tooi-related documents (user's manual)

| Document Name                                  |                                                      | Docume                  | nt Number               |
|------------------------------------------------|------------------------------------------------------|-------------------------|-------------------------|
|                                                | Japanese                                             | English                 |                         |
| RA78K Series Assembler Package                 | Operation                                            | EEU-809                 | EEU-1399                |
|                                                | Language                                             | EEU-815                 | EEU-1404                |
| RA78K Series Structured Assembler Preprocessor |                                                      | EEU-817                 | EEU-1402                |
| CC78K Series C Compiler                        | Operation                                            | EEU-656                 | EEU-1280                |
|                                                | Language                                             | EEU-655                 | EEU-1284                |
| CC78K0 C Compiler                              | Operation                                            | U11517J                 | _                       |
|                                                | Language                                             | U11518J                 | _                       |
| CC78K/0 C Compiler Application Note            | Programming Know-how                                 | EEA-618                 | EEA-1208                |
| CC78K Series Library Source File               | EEU-777                                              | _                       |                         |
| IE-780000-SL                                   | Planned to be published                              | Planned to be published |                         |
| IE-78K0-SL-EM                                  |                                                      | Planned to be published | Planned to be published |
| IE-780964-SL-EM1                               |                                                      | Planned to be published | Planned to be published |
| EP-64CW-SL                                     | · · · · · · · · · · · · · · · · · · ·                | Planned to be published | Planned to be published |
| EP-64GC-SL                                     |                                                      | Planned to be published | Planned to be published |
| SM78K0 System Simulator Windows Base           | Reference                                            | U10181J                 | U10181E                 |
| SM78K Series System Simulator                  | External Parts User Open<br>Interface Specifications | U10092J                 | U10092E                 |
| ID78K0 Integrated Debugger EWS Base            | Reference                                            | U11151J                 |                         |
| ID78K0 Integrated Debugger PC Base             | Reference                                            | U11539J                 |                         |
| ID78K0 Integrated Debugger Windows Base Guide  |                                                      | U11649J                 |                         |

# Embedded software-related documents (user's manual)

| Document Name                                                                      |              | Document Number |          |
|------------------------------------------------------------------------------------|--------------|-----------------|----------|
|                                                                                    |              | Japanese        | English  |
| 78K/0 Series Real-time OS                                                          | Fundamental  | U11537J         | _        |
|                                                                                    | Installation | U11536J         |          |
|                                                                                    | Technical    | U11538J         |          |
| 78K/0 Series OS MX78K0                                                             | Fundamental  | EEU-5010        |          |
| Fuzzy Knowledge Data Creation Tool                                                 |              | EEU-829         | EEU-1438 |
| 78K/0, 78K/II, 87AD Series Fuzzy Inference Development Support System - Translator |              | EEU-862         | EEU-1444 |
| 78K/0 Series Fuzzy Inference Development Support System - Fuzzy Inference Module   |              | EEU-858         | EEU-1441 |
| 78K/0 Series Fuzzy Inference Development Support System - F                        |              | EEU-921         | EEU-1458 |

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

Η

🖿 6427525 0099447 2ЪЪ 🖿

#### Other related documents

| Document Name                                               | Document Number |          |  |
|-------------------------------------------------------------|-----------------|----------|--|
|                                                             | Japanese        | English  |  |
| IC Package Manual                                           | C10943X         | 10943X   |  |
| Semiconductor Device Mounting Technology Manual             | C10535J         | C10535E  |  |
| Quality Grades on NEC Semiconductor Devices                 | C11531J         | C11531E  |  |
| NEC Semiconductor Device Reliability/Quality Control System | C10983J         | C10983E  |  |
| Electrostatic Discharge (ESD) Test                          | MEM-539         | _        |  |
| Guide to Quality Assurance for Semiconductor Devices        | C11893J         | MEI-1202 |  |
| Microcontroller Related Product Guide - Other Manufactures  | U11416J         | _        |  |

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

T

🖿 6427525 0099448 158 🖿

Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### CONTENTS

| CHAPT  | ER 1 G | ENERAL                               | 1        |
|--------|--------|--------------------------------------|----------|
| 1.1    | Featu  | Ires                                 | 1        |
| 1.2    |        | cation Field                         | 1        |
| 1.3    | Orde   | ring Information                     | 2        |
| 1.4    | Pin C  | onfiguration (Top View)              | 3        |
| 1.5    | Produ  | uct Development of 78K/0 Series      | 6        |
| 1.6    | Block  | Diagram                              | 8        |
| 1.7    | Funct  | tional Outline                       | 9        |
| CHAPT  | ER 2 P | IN FUNCTIONS                         | 11       |
| 2.1    | List o | f Pin Functions                      | 11       |
| 2.2    | Desci  | ription of Pin Functions             | 13       |
|        | 2.2.1  | P00 to P03 (Port0)                   | 13       |
|        | 2.2.2  | P10 to P17 (Port1)                   | 13       |
|        | 2.2.3  | P20 to P26 (Port2)                   | 13       |
|        | 2.2.4  | P30 to P37 (Port3)                   |          |
|        | 2.2.5  | P40 to P47 (Port4)                   | 15       |
|        | 2.2.6  | P50 to P57 (Port5)                   | 15       |
|        | 2.2.7  | P64 to P67 (Port6)                   | 16       |
|        | 2.2.8  | TO70 to TO75                         | 16       |
|        | 2.2.9  | AVREF                                | 16       |
|        | 2.2.10 | AVDD                                 | 16       |
|        | 2.2.11 | AVss                                 | 16       |
|        | 2.2.12 | RESET                                | 16       |
|        | 2.2.13 | X1 and X2                            | 17       |
|        | 2.2.14 | VDD0, VDD1                           | 17       |
|        | 2.2.15 | Vsso, Vss1                           | 17       |
|        | 2.2.16 | Ver (µPD78F0924, 78F0964 only)       | 17       |
|        | 2.2.17 | TEST (mask ROM model only)           | 17       |
| 2.3    |        | nmended Connection of Unused Pins    | 17       |
|        |        | entres connection of onused Fins     | 18       |
| CHAPTE | ER 3 C | PU ARCHITECTURE                      | 19       |
| 3.1    | Memo   | ry Space                             | 19       |
|        | 3.1.1  | Internal program memory space        | 24       |
|        | 3.1.2  | Internal data memory space           | 25       |
|        | 3.1.3  | Special function register (SFR) area | 25       |
|        | 3.1.4  | External memory space                | 25       |
| 3.2    | Proce  | ssor Registers                       | 26       |
|        | 3.2.1  | Control registers                    | 26       |
|        | 3.2.2  | General-purpose registers            | 29       |
|        | 3.2.3  | Special function registers (SFRs)    | 29<br>31 |
| 3.3    | Addre  | ssing Instruction Address            |          |
|        | 3.3.1  | Relative addressing                  | 35       |
|        | 3.3.2  | Immediate addressing                 | 35       |
|        |        | ·                                    | 36       |

■ 6427525 0099449 094 ■

— i —

.

|       | 3.3.3   | Table indirect addressing                  | 37              |
|-------|---------|--------------------------------------------|-----------------|
|       | 3.3.4   | Register addressing                        | 38              |
| 3.4   | Addre   | ssing of Operand Address                   | 39              |
|       | 3.4.1   | Data memory addressing                     | 39              |
|       | 3.4.2   | Implied addressing                         | 44              |
|       | 3.4.3   | Register addressing                        | 45              |
|       | 3.4.4   | Direct addressing                          | 46              |
|       | 3.4.5   | Short direct addressing                    | 47              |
|       | 3.4.6   | Special function register (SFR) addressing | 49              |
|       | 3.4.7   | Register indirect addressing               | 50              |
|       | 3.4.8   | Based addressing                           | 51              |
|       | 3.4.9   | Based indexed addressing                   | 52              |
|       | 3.4.10  | Stack addressing                           | 53              |
|       |         |                                            |                 |
|       |         | DRT FUNCTIONS                              | 55              |
| 4.1   |         | ons of Ports                               | 55              |
| 4.2   |         | onfiguration                               | 57              |
|       | 4.2.1   | Port 0                                     | 57              |
|       | 4.2.2   | Port 1                                     | 58              |
|       | 4.2.3   | Port 2                                     | 59              |
| ,     | 4.2.4   | Port 3                                     | 60              |
|       | 4.2.5   | Port 4                                     | 61              |
|       | 4.2.6   | Port 5                                     | 62              |
|       | 4.2.7   | Port 6                                     | 63              |
| 4.3   |         | ers Controlling Port Functions             | 64              |
| 4.4   |         | tion of Port Functions                     | 66              |
|       | 4.4.1   | Writing to I/O port                        | 66              |
|       | 4.4.2   | Reading from I/O port                      | 66              |
|       | 4.4.3   | Arithmetic operation of I/O port           | 66              |
| СНАРТ | ER 5 CL | OCK GENERATION CIRCUIT                     | 67              |
| 5.1   |         | on of Clock Generation Circuit             | 67              |
| 5.2   |         | uration of Clock Generation Circuit        | 67              |
| 5.3   |         | er Controlling Clock Generation Circuit    | 68              |
| 5.4   | _       | Clock Oscillation Circuits                 |                 |
|       | 5.4.1   | System clock oscillation circuit           | 69<br>69        |
|       | 5.4.2   | Divider circuit                            | 69<br>71        |
| 5.5   |         | ion of Clock Generation Circuit            | 71              |
| 5.6   |         | ing Setting of CPU Clock                   | 72              |
|       | 5.6.1   | Time required for switching CPU clock      | <b>73</b><br>73 |
|       |         | Switching CPU clock                        |                 |
|       | U.U.L   |                                            | 74              |
| СНАРТ | R6 RE   | AL-TIME OUTPUT PORT                        | 75              |
| 6.1   |         | me Output Port Functions                   | 75              |
| 6.2   |         | me Output Port Configuration               | 76              |
| 6.3   |         | ers Controlling Real-Time Output Port      | 78              |
| 6.4   |         | ion of Real-Time Output Port               | 80              |
| 6.5   |         | Real-Time Output Port                      | 81              |
| 6.6   | Notes o | on Real-Time Output Port                   | 81              |
|       |         | ■ 6427525 0099450 806 <b>■</b>             |                 |
|       |         |                                            |                 |

.....

| CHAPT      | R 7 10-BIT INVERTER CONTROL TIMER                     | 83  |
|------------|-------------------------------------------------------|-----|
| 7.1        | Functions of 10-Bit Inverter Control Timer            |     |
| 7.2        | Configuration of 10-Bit Inverter Control Timer        |     |
| 7.3        | Registers Controlling 10-bit Inverter Control Timer   |     |
| 7.4        | Operation of 10-Bit Inverter Control Timer            |     |
|            |                                                       |     |
| CHAPTI     | R 8 8-BIT TIMER/EVENT COUNTER                         | 97  |
| 8.1        | Function of 8-Bit Timer/Event Counter                 | 97  |
| 8.2        | Configuration of 8-Bit Timer/Event Counter            |     |
| 8.3        | Registers Controlling 8-Bit Timer/Event Counters      |     |
| 8.4        | Operation of 8-Bit Timer/Event Counter                | 108 |
|            | 8.4.1 Operation as interval timer (8-bit operation)   |     |
|            | 8.4.2 Operation as external event counter             |     |
|            | 8.4.3 Square wave output operation (8-bit resolution) |     |
|            | 8.4.4 8-bit PWM output operation                      |     |
|            | 8.4.5 Operation as interval timer (16-bit operation)  | 116 |
| 8.5        | Notes on Using 8-Bit Timer/Event Counters             | 118 |
|            |                                                       |     |
| 9.1        | R 9 WATCHDOG TIMER                                    | 119 |
| 9.1<br>9.2 | Functions of Watchdog Timer                           | 119 |
| 9.2<br>9.3 | Configuration of Watchdog Timer                       | 120 |
|            | Registers Controlling Watchdog Timer                  | 121 |
| 9.4        | Operation of Watchdog Timer                           | 124 |
|            | 9.4.1 Operation as watchdog timer                     |     |
|            | 9.4.2 Operation as interval timer                     | 125 |
| CHAPTE     | R 10 8-BIT A/D CONVERTER (μPD780924 SUBSERIES)        | 127 |
| 10.1       | Function of A/D Converter                             | 127 |
| 10.2       | Configuration of A/D Converter                        | 127 |
| 10.3       | Registers Controlling A/D Converter                   | 127 |
| 10.4       | Operation of A/D Converter                            | 133 |
|            | 10.4.1 Basic operation of A/D converter               |     |
|            | 10.4.2 Input voltage and conversion result            | 135 |
|            | 10.4.3 Operation mode of A/D converter                | 135 |
| 10.5       | Notes on A/D Converter                                | 138 |
|            |                                                       |     |
| CHAPIE     | R 11 10-BIT A/D CONVERTER (μPD780964 SUBSERIES)       | 141 |
| 11.1       | Function of A/D Converter                             | 141 |
| 11.2       | Configuration of A/D Converter                        | 141 |
| 11.3       | Registers Controlling A/D Converter                   | 144 |
| 11.4       | Operation of A/D Converter                            | 147 |
|            | 11.4.1 Basic operation of A/D converter               | 147 |
|            | 11.4.2 Input voltage and conversion result            | 149 |
|            | 11.4.3 Operation mode of A/D converter                | 150 |
| 11.5       | Notes on A/D Converter                                | 152 |
| CHAPTE     | 12 SERIAL INTERFACE                                   |     |
| 12.1       | Serial Interface Functions                            | 155 |
| -          |                                                       | 155 |

· \_\_\_\_

•

- iii -6427525 0099451 742 🛲

. \_\_\_\_

-----

\_\_\_\_\_

| 12.2   | Serial Interface Configuration                                                                                   | 156        |
|--------|------------------------------------------------------------------------------------------------------------------|------------|
|        | Registers Controlling Serial Interface                                                                           | 159        |
| 12.4   | Operation of Serial Interface                                                                                    | 166        |
|        | 12.4.1 Operation stop mode                                                                                       | 166        |
|        | 12.4.2 Asynchronous serial interface (UART) mode                                                                 | 166        |
|        | 12.4.3 Infrared data transfer (IrDA) mode                                                                        | 179        |
|        |                                                                                                                  |            |
|        | ER 13 INTERRUPT FUNCTIONS                                                                                        | 183        |
|        | Types of Interrupt Functions                                                                                     | 183        |
|        | Interrupt Sources and Configuration                                                                              | 183        |
|        | Registers Controlling Interrupt Function                                                                         | 187        |
| 13.4   | Interrupt Processing Operation                                                                                   | 192        |
|        | 13.4.1 Non-maskable interrupt acceptance operation                                                               | 192        |
|        | 13.4.2 Maskable interrupt acceptance operation                                                                   | 195        |
|        | 13.4.3 Software interrupt acceptance operation                                                                   | 197        |
|        | 13.4.4 Multiplexed interrupt processing                                                                          | 198        |
|        | 13.4.5 Pending interrupt                                                                                         | 200        |
| СНАРТЕ | R 14 EXTERNAL DEVICE EXTENSION FUNCTION                                                                          | 001        |
|        | External Device Extension Function                                                                               | 201<br>201 |
|        | Registers Controlling External Device Extension Function                                                         | 201        |
|        | Timing of External Device Extension Function                                                                     | 204        |
|        | Example of Connection with Memory                                                                                | 212        |
|        |                                                                                                                  | 212        |
| CHAPTE | R 15 STANDBY FUNCTION                                                                                            | 213        |
| 15.1   | Standby Function and Configuration                                                                               | 213        |
|        | 15.1.1 Standby function                                                                                          | 213        |
|        | 15.1.2 Registers controlling standby function                                                                    | 214        |
| 15.2   | Operation of Standby Function                                                                                    | 215        |
|        | 15.2.1 HALT mode                                                                                                 | 215        |
|        | 15.2.2 STOP mode                                                                                                 | 218        |
|        |                                                                                                                  |            |
| CHAPTE | R 16 RESET FUNCTION                                                                                              | 223        |
|        |                                                                                                                  |            |
| CHAPTE | R 17 μPD78F0924, 78F0964                                                                                         | 227        |
| 17.1   | Selecting Communication Mode                                                                                     | 227        |
| 17.2   | Function of Flash Memory Programming                                                                             | 228        |
| 17.3   | Connecting Flashpro                                                                                              | 229        |
| CHAPTE | R 18 INSTRUCTION SET                                                                                             |            |
| 18.1   | R 18 INSTRUCTION SET                                                                                             | 231        |
|        | 18.1.1 Operand representation and description formats                                                            | 232        |
|        | 18.1.1       Operand representation and description formats         18.1.2       Description of operation column | 232        |
|        | 18.1.3     Description in flag operation column                                                                  | 233        |
| 18.2   | Operation List                                                                                                   | 233        |
| 18.3   | Instruction List by Addressing                                                                                   | 234<br>242 |
|        |                                                                                                                  | <b>242</b> |
| APPEND | X A DEVELOPMENT TOOLS                                                                                            | 247        |
|        |                                                                                                                  |            |

- iv -6427525 0099452 689 🎟

| <b>A.</b> 1 | Language Processing Software                                                | 249 |
|-------------|-----------------------------------------------------------------------------|-----|
| A.2         | Flash Memory Writing Tools                                                  | 250 |
| A.3         | Debugging Tools                                                             | 251 |
|             | A.3.1 Hardware                                                              | 251 |
|             | A.3.2 Software                                                              | 252 |
| A.4         | OS for IBM PC                                                               | 254 |
| A.5         | Changing Other In-Circuit Emulators to In-Circuit Emulator for 78K/0 Series | 255 |
|             |                                                                             |     |
| APPEN       | DIX B EMBEDDED SOFTWARE                                                     | 257 |
| <b>B.1</b>  | Real-Time OS                                                                | 258 |
| B.2         |                                                                             | 260 |
| APPEN       | DIX C REGISTER INDEX                                                        | 261 |
| C.1         | Register Index (In Alphabetical Order with Respect to the Register Name)    | 261 |
| C.2         | Register Index (In Alphabetical Order with Respect to the Register Symbol)  | 264 |

#### -v-■ 6427525 0099453 515 ■

\_\_\_\_\_

-----

# LIST OF FIGURES (1/4)

.

| Figure No. | Title                                                | Page |
|------------|------------------------------------------------------|------|
| 3-1.       | Memory Map (μPD780921, 780961)                       | 19   |
| 3-2.       | Memory Map (µPD780922, 780962)                       | 20   |
| 3-3.       | Memory Map (μPD780923, 780963)                       | 21   |
| 3-4.       | Memory Map (μPD780924, 780964)                       | 22   |
| 3-5.       | Memory Map (μPD78F0924, 78F0964)                     | 23   |
| 3-6.       | Program Counter Configuration                        | 26   |
| 3-7.       | Program Status Word Configuration                    | 26   |
| 3-8.       | Stack Pointer Configuration                          | 27   |
| 3-9.       | Data Saved to Stack Memory                           | 28   |
| 3-10.      | Data Restored from Stack Memory                      | 28   |
| 3-11.      | General-Purpose Register Configuration               | 30   |
| 3-12.      | Data Memory Addressing (µPD780921, 780961)           | 39   |
| 3-13.      | Data Memory Addressing (μPD780922, 780962)           | 40   |
| 3-14.      | Data Memory Addressing (µPD780923, 780963)           | 41   |
| 3-15.      | Data Memory Addressing (µPD780924, 780964)           | 42   |
| 3-16.      | Data Memory Addressing (μPD78F0924, 78F0964)         | 43   |
| 4-1.       | Types of Ports                                       | 55   |
| 4-2.       | Block Diagram of P00 to P03                          | 58   |
| 4-3.       | Block Diagram of P10 to P17                          | 58   |
| 4-4.       | Block Diagram of P20 to P26                          | 59   |
| 4-5.       | Block Diagram of P30 to P37                          | 60   |
| 4-6.       | Block Diagram of P40 to P47                          | 61   |
| 4-7.       | Block Diagram of P50 to P57                          | 62   |
| 4-8.       | Block Diagram of P64 to P67                          | 63   |
| 4-9.       | Format of Port Mode Register                         | 64   |
| 4-10.      | Format of Pull-Up Resistor Option Register           | 65   |
| 5-1.       | Clock Generator Block Diagram                        | 67   |
| 5-2.       | Format of Processor Clock Control Register           | 68   |
| 5-3.       | External Circuit of System Clock Oscillation Circuit | 69   |
| 5-4.       | Incorrect Examples of Resonator Connection           | 70   |
| 5-5.       | Switching between System Clock and CPU Clock         | 74   |
| 6-1.       | Real-Time Output Port Block Diagram                  | 76   |
| 6-2.       | Real-Time Output Buffer Register Configuration       | 77   |
| 6-3.       | Format of Real-Time Output Port Mode Register        | 78   |
| 6-4.       | Format of Real-Time Output Port Control Register     | 79   |
| 6-5.       | Example of Operation Timing of Real-Time Output Port |      |
|            | (when EXTR0 = 0, BYTE0 = 0)                          | 80   |
| 7-1.       | Block Diagram of 10-Bit Inverter Control Timer       | 84   |
| 7-2.       | Inverter Timer Control Register 7 Format             | 88   |



# LIST OF FIGURES (2/4)

----

| Figure No. | Title                                                                          | Page |
|------------|--------------------------------------------------------------------------------|------|
| 7-3.       | Inverter Timer Mode Register 7 Format                                          | 89   |
| 7-4.       | TM7 Operation Timing (Basic Operation)                                         | 93   |
| 7-5.       | TM7 Operation Timing (CMn (BFCMn) ≥ CM3 (BFCM3))                               | 94   |
| 7-6.       | TM7 Operation Timing (CMn (BFCMn) = 000H)                                      | 95   |
| 7-7.       | TM7 Operation Timing (CMn (BFCMn) = CM3 - 1/2DTM,                              |      |
|            | CMn (BFCMn) > CM3 - 1/2DTM)                                                    | 96   |
| 8-1.       | 8-Bit Timer/Event Counter 50 (TM50) Block Diagram                              | 99   |
| 8-2.       | 8-Bit Timer/Event Counter 51 (TM51) Block Diagram                              | 99   |
| 8-3.       | 8-Bit Timer/Event Counter 52 (TM52) Block Diagram                              | 100  |
| 8-4.       | Format of 8-Bit Timer Mode Control Register 50                                 | 103  |
| 8-5.       | Format of 8-Bit Timer Mode Control Register 51                                 | 104  |
| 8-6.       | Format of 8-Bit Timer Mode Control Register 52                                 | 105  |
| 8-7.       | Format of Timer Clock Select Register 50                                       | 106  |
| 8-8.       | Format of Timer Clock Select Register 51                                       | 107  |
| 8-9.       | Format of Timer Clock Select Register 52                                       | 107  |
| 8-10.      | Interval Timer Operation Timing                                                | 108  |
| 8-11.      | External Event Counter Operation Timing (with rising edge specified)           | 111  |
| 8-12.      | PWM Output Operation Timing                                                    | 114  |
| 8-13.      | Operation Timing When CR5n is Changed                                          | 115  |
| 8-14.      | 16-Bit Resolution Cascade Mode (with TM50 and TM51)                            | 116  |
| 8-15.      | 16-Bit Resolution Cascade Mode (with TM51 and TM52)                            | 117  |
| 8-16.      | Start Timing of 8-Bit Timer Counter                                            | 118  |
| 8-17.      | Timing after Changing Values of Compare Registers during Timer Count Operation | 118  |
| 9-1.       | Watchdog Timer Block Diagram                                                   | 120  |
| 9-2.       | Format of Watchdog Timer Clock Select Register                                 | 121  |
| 9-3.       | Format of Watchdog Timer Mode Register                                         | 122  |
| 9-4.       | Format of Oscillation Stabilization Time Select Register                       | 123  |
| 10-1.      | Block Diagram of 8-Bit A/D Converter                                           | 128  |
| 10-2.      | Format of A/D Converter Mode Register 0                                        | 131  |
| 10-3.      | Format of Analog Input Channel Specification Register 0                        | 132  |
| 10-4.      | Basic Operation of A/D Converter                                               | 134  |
| 10-5.      | Relations between Analog Input Voltage and A/D Conversion Result               | 135  |
| 10-6.      | A/D Conversion by Hardware Start (When falling edge is specified)              | 136  |
| 10-7.      | A/D Conversion by Software Start                                               | 137  |
| 10-8.      | Example of Reducing Current Consumption in Standby Mode                        | 138  |
| 10-9.      | Processing Analog Input Pin                                                    | 139  |
| 10-10.     | A/D Conversion End Interrupt Generation Timing                                 | 140  |
| 10-11.     | Processing of AVod Pin                                                         | 140  |
| 11-1.      | Block Diagram of 10-Bit A/D Converter                                          | 142  |



\_\_\_\_\_

\_\_\_\_\_

# LIST OF FIGURES (3/4)

| Figure No.     | Title                                                                                                            |            |  |  |  |  |  |
|----------------|------------------------------------------------------------------------------------------------------------------|------------|--|--|--|--|--|
| 11-2.          | Format of A/D Converter Mode Register 0                                                                          | 145        |  |  |  |  |  |
| 11-3.          | Format of Analog Input Channel Specification Register 0                                                          | 146        |  |  |  |  |  |
| 11-4.          | Basic Operation of A/D Converter                                                                                 | 148        |  |  |  |  |  |
| 11-5.          | Relations between Analog Input Voltage and A/D Conversion Result                                                 | 149        |  |  |  |  |  |
| 11-6.          | A/D Conversion by Hardware Start (When falling edge is specified)                                                | 150        |  |  |  |  |  |
| 11-7.          | A/D Conversion by Software Start                                                                                 | 151        |  |  |  |  |  |
| 11-8.          | Example of Reducing Current Consumption in Standby Mode                                                          | 152        |  |  |  |  |  |
| 11 <b>-9</b> . | Processing Analog Input Pin                                                                                      |            |  |  |  |  |  |
| 11-10.         | A/D Conversion End Interrupt Generation Timing                                                                   | 154        |  |  |  |  |  |
| 11-11.         | Processing of AVoo Pin                                                                                           | 154        |  |  |  |  |  |
| 12-1.          | Serial Interface (UART00) Block Diagram                                                                          | 156        |  |  |  |  |  |
| 12-2.          | Serial Interface (UART01) Block Diagram                                                                          | 157        |  |  |  |  |  |
| 12-3.          | Format of Asynchronous Serial Interface Mode Register 0                                                          | 160        |  |  |  |  |  |
| 12-4.          | Format of Asynchronous Serial Interface Mode Register 1                                                          | 161        |  |  |  |  |  |
| 12-5.          | Format of Asynchronous Serial Interface Status Register 0                                                        | 162        |  |  |  |  |  |
| 12-6.          | Format of Asynchronous Serial Interface Status Register 1                                                        | 163        |  |  |  |  |  |
| 12-7.          | Format of Baud Rate Generator Control Register 0                                                                 | 164        |  |  |  |  |  |
| 12-8.          | Format of Baud Rate Generator Control Register 1                                                                 | 165        |  |  |  |  |  |
| 12-9.          | Asynchronous Serial Interface Transmit/Receive Data Format                                                       | 174        |  |  |  |  |  |
| 12-10.         | Asynchronous Serial Interface Transmission Completion Interrupt Timing                                           | 176        |  |  |  |  |  |
| 12-11.         | Asynchronous Serial Interface Reception Completion Interrupt Timing                                              | 177        |  |  |  |  |  |
| 12-12.         | Receive Error Timing                                                                                             | 178        |  |  |  |  |  |
| 12-13.         | Comparison of Data Formats in IrDA Mode and UART Mode                                                            | 179        |  |  |  |  |  |
| 13-1.          | Basic Configuration of Interrupt Function                                                                        | 185        |  |  |  |  |  |
| 13-2.          | Format of Interrupt Request Flag Registers                                                                       | 188        |  |  |  |  |  |
| 13-3.          | Format of Interrupt Mask Flag Register                                                                           | 189        |  |  |  |  |  |
| 13-4.          | Format of Priority Specification Flag Register                                                                   | 190        |  |  |  |  |  |
| 13-5.          | Formats of External Interrupt Rising Edge Enable Register and External Interrupt<br>Falling Edge Enable Register |            |  |  |  |  |  |
| 13-6.          | Configuration of Program Status Word                                                                             | 191        |  |  |  |  |  |
| 13-7.          | Flowchart of Non-Maskable Interrupt Acceptance                                                                   | 192        |  |  |  |  |  |
| 13-8.          | Timing of Non-Maskable Interrupt Acceptance                                                                      | 193        |  |  |  |  |  |
| 13-9.          | Accepting Non-Maskable Interrupt Request                                                                         | 193        |  |  |  |  |  |
| 13-10.         | Interrupt Acceptance Program Algorithm                                                                           | 194        |  |  |  |  |  |
| 13-11.         | Interrupt Acceptance Timing (Minimum Time)                                                                       | 196        |  |  |  |  |  |
| 13-12.         | Interrupt Acceptance Timing (Maximum Time)                                                                       | 197        |  |  |  |  |  |
| 13-13.         | Example of Multiplexed Interrupt                                                                                 | 197        |  |  |  |  |  |
| 13-14.         | Pending Interrupt Request                                                                                        | 199<br>200 |  |  |  |  |  |
| 14-1.          | Memory Map when External Device Extension Function Is Used                                                       | 202        |  |  |  |  |  |
| 14-2.          | Format of Memory Extension Mode Register                                                                         | 202        |  |  |  |  |  |
|                |                                                                                                                  |            |  |  |  |  |  |



\_\_\_\_\_

\_\_\_\_\_

\_\_\_\_ .

# LIST OF FIGURES (4/4)

| Figure No. | Title                                                              | Page |
|------------|--------------------------------------------------------------------|------|
| 14-3.      | Format of Memory Extension Wait Setting Register                   | 205  |
| 14-4.      | Format of Memory Size Select Register                              | 206  |
| 14-5.      | Instruction Fetch from External Memory                             | 208  |
| 14-6.      | Read Timing of External Memory                                     | 209  |
| 14-7.      | Write Timing of External Memory                                    | 210  |
| 14-8.      | Read-Modify-Write Timing of External Memory                        | 211  |
| 14-9.      | Example of Connecting $\mu$ PD780924 and Memories                  | 212  |
| 15-1.      | Format of Oscillation Stabilization Time Select Register           | 214  |
| 15-2.      | Releasing HALT Mode by Interrupt                                   | 216  |
| 15-3.      | Releasing HALT Mode by RESET Input                                 | 217  |
| 15-4.      | Releasing STOP Mode by Interrupt                                   | 220  |
| 15-5.      | Releasing STOP Mode by RESET Input                                 | 221  |
| 16-1.      | Block Diagram of Reset Function                                    | 223  |
| 16-2.      | Reset Timing by RESET Input                                        | 224  |
| 16-3.      | Reset Timing by Overflow in Watchdog Timer                         | 224  |
| 16-4.      | Reset Timing by RESET Input in STOP Mode                           | 224  |
| 17-1.      | Communication Mode Selecting Format                                | 227  |
| 17-2.      | Connection of Flashpro in UART Mode (when UART00 is used)          | 229  |
| 17-3.      | Connection of Flashpro in Pseudo 3-Wire Mode (when port 2 is used) | 229  |
| A-1.       | Development Tool Configuration                                     | 248  |



\_.

-----

# LIST OF TABLES (1/2)

| Table No. | Title                                                                        |     |  |  |  |  |  |
|-----------|------------------------------------------------------------------------------|-----|--|--|--|--|--|
| 2-1.      | Recommended Connection of Unused Pins                                        | 18  |  |  |  |  |  |
| 3-1.      | Internal ROM Capacity                                                        | 24  |  |  |  |  |  |
| 3-2.      | Vector Table                                                                 | 24  |  |  |  |  |  |
| 3-3.      | Internal High-Speed RAM Capacity                                             | 25  |  |  |  |  |  |
| 3-4.      | Internal High-Speed RAM Area                                                 | 27  |  |  |  |  |  |
| 3-5.      | Absolute Addresses of General-Purpose Registers                              | 29  |  |  |  |  |  |
| 3-6.      | Special Function Register List                                               | 32  |  |  |  |  |  |
| 4-1.      | Port Functions                                                               | 56  |  |  |  |  |  |
| 4-2.      | Port Configuration                                                           | 57  |  |  |  |  |  |
| 5-1.      | Configuration of Clock Generation Circuit                                    | 67  |  |  |  |  |  |
| 5-2.      | Maximum Time Required for Switching CPU Clock                                | 73  |  |  |  |  |  |
| 6-1.      | Real-Time Output Port Configuration                                          | 76  |  |  |  |  |  |
| 6-2.      | Operation in Real-Time Output Buffer Register Manipulation                   | 77  |  |  |  |  |  |
| 6-3.      | Real-Time Output Port Operating Mode and Output Trigger                      | 79  |  |  |  |  |  |
| 7-1.      | Configuration of 10-Bit Inverter Control Timer                               | 83  |  |  |  |  |  |
| 8-1.      | Configuration of 8-Bit Timer/Event Counter                                   | 98  |  |  |  |  |  |
| 9-1.      | Inadvertent Loop Detection Time of Watchdog Timer                            | 119 |  |  |  |  |  |
| 9-2.      | Interval Time                                                                | 119 |  |  |  |  |  |
| 9-3.      | Configuration of Watchdog Timer                                              | 120 |  |  |  |  |  |
| 9-4.      | Inadvertent Loop Detection Time of Watchdog Timer                            | 124 |  |  |  |  |  |
| . 9-5.    | Interval Time of Interval Timer                                              | 125 |  |  |  |  |  |
| 10-1.     | Configuration of 8-Bit A/D Converter                                         | 127 |  |  |  |  |  |
| 11-1.     | Configuration of 10-Bit A/D Converter                                        | 141 |  |  |  |  |  |
| 12-1.     | Serial Interface Configuration                                               | 156 |  |  |  |  |  |
| 12-2.     | Relations between Source Clock of 5-Bit Counter and Value of m (with UART00) | 172 |  |  |  |  |  |
| 12-3.     | Relations between Source Clock of 5-Bit Counter and Value of m (with UART01) | 172 |  |  |  |  |  |
| 12-4.     | Relation between the System Clock and Baud Rate                              | 173 |  |  |  |  |  |
| 12-5.     | Receive Error Causes                                                         | 178 |  |  |  |  |  |
| 12-6.     | Bit Rate and Pulse Width                                                     | 180 |  |  |  |  |  |
| 12-7.     | Baud Rate That Can Be Set in IrDA Mode                                       | 180 |  |  |  |  |  |
| 13-1.     | Interrupt Source List                                                        | 184 |  |  |  |  |  |
| 13-2.     | Flags Corresponding to Respective Interrupt Request Sources                  | 187 |  |  |  |  |  |



# LIST OF TABLES (2/2)

| Table No. | Title                                                                  |     |  |  |  |  |
|-----------|------------------------------------------------------------------------|-----|--|--|--|--|
| 13-3.     | Time from Generation of Maskable Interrupt Request to Processing       | 195 |  |  |  |  |
| 13-4.     | Interrupt Requests that Can Be Multiplexed during Interrupt Processing | 198 |  |  |  |  |
| 14-1.     | Pin Functions in External Memory Extension Mode                        | 201 |  |  |  |  |
| 14-2.     | Status of Ports 4 to 6 in External Memory Extension Mode               | 201 |  |  |  |  |
| 14-3.     | Set Value of Memory Size Select Register                               | 206 |  |  |  |  |
| 15-1.     | Operation Status in HALT Mode                                          | 215 |  |  |  |  |
| 15-2.     | Operation after Release of HALT Mode                                   | 217 |  |  |  |  |
| 15-3.     | Operation Status in STOP Mode                                          | 219 |  |  |  |  |
| 15-4.     | Operation after Release of STOP Mode                                   | 221 |  |  |  |  |
| 16-1.     | Status of Each Hardware after Reset                                    | 225 |  |  |  |  |
| 17-1.     | Communication Modes                                                    | 227 |  |  |  |  |
| 17-2.     | Major Functions of Flash Memory Programming                            | 228 |  |  |  |  |
| 18-1.     | Operand Representation and Description Formats                         | 232 |  |  |  |  |
| A-1.      | Changing Other In-Circuit Emulators to IE-780000-SL                    | 255 |  |  |  |  |

- xi -6427525 0099459 T33 🖿

.

# PAGE(S) INTENTIONALLY BLANK



#### 1.1 Features

On-chip ROM and RAM

| Item                | Program Memory                    | Data Memory                  |  |  |
|---------------------|-----------------------------------|------------------------------|--|--|
| Part Number         | (ROM)                             | Internal High-Speed RAM      |  |  |
| μPD780921, 780961   | 8 Kbytes                          | 512 bytes                    |  |  |
| μPD780922, 780962   | 16 Kbytes                         |                              |  |  |
| μPD780923, 780963   | 24 Kbytes                         | 1024 bytes                   |  |  |
| μPD780924, 780964   | 32 Kbytes                         | -                            |  |  |
| μPD78F0924, 78F0964 | 32 KbytesNote 1<br>(flash memory) | 1024 bytes <sup>Note 2</sup> |  |  |

Notes 1. 8, 16, 24, or 32 Kbytes is selectable by using memory size select register (IMS).
2. 512 or 1024 bytes is selectable by using IMS.

- Lower EMI (Electro Magnetic Interfarence) noise than existing  $\mu$ PD78014 and 78018F subseries
- External memory extension space: 48 Kbytes
- Minimum instruction execution time: 0.24  $\mu$ s (fx = 8.38-MHz operation)
- Instruction set suitable for system control
  - · Bit processing in entire address space
  - Multiplication/division instructions
- I/O port: 47 lines
- A/D converter
  - 8-bit resolution × 8 channels (µPD780924 subseries)
  - 10-bit resolution × 8 channels (µPD780964 subseries)
- Serial interface: UART × 2 channels
- Timer: 5 channels
  - · 10-bit inverter control timer: 1 channel
  - 8-bit timer/event counter : 3 channels
  - Watchdog timer : 1 channel
- Vectored interrupt: 18 lines
- Supply voltage: VDD = 2.7 to 5.5 V

#### **1.2 Application Field**

Inverter air conditioners, washing machine, etc.

### 1.3 Ordering Information

-

2

| Part Number                | Package                                | Internal ROM |
|----------------------------|----------------------------------------|--------------|
| μPD780921CW                | 64-pin plastic shrink DIP (750 mil)    | Mask ROM     |
| μPD780921GC-∞∞-AB8         | 64-pin plastic QFP (14 $\times$ 14 mm) | Mask ROM     |
| μPD780922CW                | 64-pin plastic shrink DIP (750 mil)    | Mask ROM     |
| μPD780922GC-∞-AB8          | 64-pin plastic QFP (14 × 14 mm)        | Mask ROM     |
| μPD780923CW                | 64-pin plastic shrink DIP (750 mil)    | Mask ROM     |
| μ <b>PD780923GC-</b> ∞-AB8 | 64-pin plastic QFP (14 × 14 mm)        | Mask ROM     |
| μPD780924CW                | 64-pin plastic shrink DIP (750 mil)    | Mask ROM     |
| μPD780924GC-∞∞-AB8         | 64-pin plastic QFP (14 × 14 mm)        | Mask ROM     |
| μPD780961CW                | 64-pin plastic shrink DIP (750 mil)    | Mask ROM     |
| μPD780961GC-∞-AB8          | 64-pin plastic QFP (14 × 14 mm)        | Mask ROM     |
| µPD780962CW                | 64-pin plastic shrink DIP (750 mil)    | Mask ROM     |
| μPD780962GC-∞∞-AB8         | 64-pin plastic QFP (14 × 14 mm)        | Mask ROM     |
| µPD780963CW                | 64-pin plastic shrink DIP (750 mil)    | Mask ROM     |
| μPD780963GC-∞∞-AB8         | 64-pin plastic QFP (14 × 14 mm)        | Mask ROM     |
| μPD780964CW                | 64-pin plastic shrink DIP (750 mil)    | Mask ROM     |
| μPD780964GC-xxx-AB8        | 64-pin plastic QFP (14 × 14 mm)        | Mask ROM     |
| μPD78F0924CW               | 64-pin plastic shrink DIP (750 mil)    | Flash memory |
| μPD78F0924GC-AB8           | 64-pin plastic QFP (14 × 14 mm)        | Flash memory |
| μPD78F0964CW               | 64-pin plastic shrink DIP (750 mil)    | Flash memory |
| μPD78F0964GC-AB8           | 64-pin plastic QFP (14 × 14 mm)        | Flash memory |

Remark xxx indicates a ROM code suffix.

■ 6427525 0099462 528 **■** 

.\_\_\_\_

#### 1.4 Pin Configuration (Top View)

64-pin plastic shrink DIP (750 mil)

µPD780921CW-xxx, 780922CW-xxx, 780923CW-xxx, 780924CW-xxx, 78F0924CW µPD780961CW-xxx, 780962CW-xxx, 780963CW-xxx, 780964CW-xxx, 78F0964CW

| P40/AD0 O           |    | 64                   |
|---------------------|----|----------------------|
| P41/AD1 O           | 2  | 63 P66/WAIT          |
| P42/AD2 O           | 3  | 62 P65/WR            |
| P43/AD3 O           | 4  | 61                   |
| P44/AD4 O           | 5  | 60 O P37/RTP7        |
| P45/AD5 O           | 6  | 59 O P36/RTP6        |
| P46/AD6 O           | 7  | 58 O P35/RTP5        |
| P47/AD7 O           | 8  | 57 O P34/RTP4        |
| P50/A8 O            | 9  | 56 O P33/RTP3        |
| P51/A9 O            | 10 | 55 O P32/RTP2        |
| P52/A10 O           | 11 | 54 O P31/RTP1        |
| P53/A11 O+++        | 12 | 53 O P30/RTP0        |
| P54/A12 O           | 13 | 52 O P01/INTP1       |
| P55/A13 O           | 14 | 51 P00/INTP0/TOFF7   |
| P56/A14 O           | 15 | 50 Vss1              |
| P57/A15 O           | 16 | 49 - O X1            |
| Vsso O              | 17 | 48 0 X2              |
| VD00 O              | 18 | 47 O TEST (VPP)      |
| T070 O <del>-</del> | 19 | 46 O P03/INTP3/ADTRG |
| T071 O              | 20 | 45 O P02/INTP2       |
| T072 O <del></del>  | 21 | 44 - O RESET         |
| T073 O <del>→</del> | 22 |                      |
| T074 O              | 23 | 42 - O AVREF         |
| T075 O              | 24 | 41 O P10/ANIO        |
| P20/RxD00 O         | 25 | 40 O P11/ANI1        |
| P21/TxD00 O         | 26 | 39 - O P12/ANI2      |
| P22/RxD01 O         | 27 | 38 O P13/ANI3        |
| P23/TxD01 O         | 28 | 37 O P14/ANI4        |
| P24/TI50/TO50 O     | 29 | 36 O P15/ANI5        |
| P25/TI51/T051 O     | 30 | 35 O P16/ANI6        |
| P26/TI52/TO52 O     | 31 | 34 O P17/ANI7        |
| V001 O              | 32 | 33 O AVss            |
|                     |    |                      |

Cautions 1. Connect the TEST pin to Vsso directly.

- 2. Connect the AVDD pin to VDDD.
- 3. Connect the AVss pin to Vsso.

#### Remarks 1. ( ): µPD78F0924, 78F0964

2. When the  $\mu$ PD780924 and 780964 subseries are used in application fields that require reduction of the noise generated from inside the microcontroller, the implementation of noise reduction measures, such as supplying voltage to VDD0 and VDD1 individually and connecting Vss0 and Vss1 to different ground lines, is recommended.

6427525 0099463 464 🎟

\_ . . .

64-pin plastic QFP (14 × 14 mm)
 μPD780921GC-∞-AB8, 780922GC-∞-AB8, 780923GC-∞-AB8, 780924GC-∞-AB8
 μPD78F0924GC-AB8
 μPD78F0924GC-AB8
 μPD780961GC-∞-AB8, 780962GC-∞-AB8, 780963GC-∞-AB8, 780964GC-∞-AB8
 μPD78F0964GC-AB8



Cautions 1. Connect the TEST pin to Vsso directly.

- 2. Connect the AVop pin to Vope.
- 3. Connect the AVss pin to Vsso.

#### Remarks 1. ( ): µPD78F0924, 78F0964

- 2. When the μPD780924 and 780964 subseries are used in application fields that require reduction of the noise generated from inside the microcontroller, the implementation of noise reduction measures, such as supplying voltage to Vodo and Vod1 individually and connecting Vsso and Vss1 to different ground lines, is recommended.
  - 🛚 6427525 0099464 3TO 📰

| A8 to A15<br>AD0 to AD7<br>ADTRG<br>ANI0 to ANI7<br>ASTB<br>AVDD<br>AVREF<br>AVSS<br>INTP0 to INTP3<br>P00 to P03<br>P10 to P17<br>P20 to P26 | : Port 0<br>: Port 1<br>: Port 2 | RD       :         RESET       :         RTP0 to RTP7       :         RxD00, RxD01       :         TEST       :         TI50 to TI52       :         TO50 to TO52,       :         TO70 to TO75       :         TOFF7       :         TxD00, TxD01       :         VDD0, VDD1       :         VPP       : | Read Strobe<br>Reset<br>Real-time Port<br>Receive Data<br>Test<br>Timer Input<br>Timer Output<br>Timer Output<br>Timer Output Off<br>Transmit Data<br>Power Supply<br>Programming Power Supply |
|-----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P10 to P17                                                                                                                                    | : Port 1                         | VDD0, VDD1                                                                                                                                                                                                                                                                                                | Power Supply                                                                                                                                                                                   |
| P30 to P37<br>P40 to P47                                                                                                                      | : Port 3<br>: Port 4             | VPP :<br>Vsso, Vss1 :<br>WAIT :                                                                                                                                                                                                                                                                           | Programming Power Supply<br>Ground<br>Wait                                                                                                                                                     |
| P50 to P57<br>P64 to P67                                                                                                                      | : Port 5<br>: Port 6             | WR         :           X1, X2         :                                                                                                                                                                                                                                                                   | Write Strobe<br>Crystal                                                                                                                                                                        |

🖬 6427525 0099465 237 🎟

-----

5

Powered by ICminer.com Electronic-Library Service CopyRight 2003

......

#### 1.5 Product Development of 78K/0 Series

The products in the 78K/0 series are listed below. The names enclosed in boxes are subseries names.



Note Under planning

6

64275250099466173 🖿

|           | Function    | ROM          |       | Tir    | ner   | ,   | 8-bit | 10-bit | 8-bit | Serial                    | 1/0 | Voo        | External  |    |  |   |
|-----------|-------------|--------------|-------|--------|-------|-----|-------|--------|-------|---------------------------|-----|------------|-----------|----|--|---|
| Subseries | Name        | Capacity     | 8-bit | 16-bit | Watch | WDT | AVD   | A/D    | D/A   | Interface                 |     | MIN. Value | Expansion |    |  |   |
| Control   | μPD78078    | 32 K to 60 K | 4ch   | 1ch    | 1ch   | 1ch | 8ch   | -      | 2ch   | 3ch                       | 88  | 1.8 V      | V         |    |  |   |
|           | μPD78070A   | -            |       |        |       |     |       |        |       | (UART: 1ch)               | 61  | 2.7 V      |           |    |  |   |
|           | μPD780018   | 48 K to 60 K |       |        |       |     |       |        | -     | 2ch (time-                | 88  | 1          |           |    |  |   |
|           |             |              |       | ļ      |       |     |       |        |       | division 3-               |     | -          |           |    |  |   |
|           | μPD780058   | 24 K to 60 K | 2ch   | ł      |       |     |       |        | 0-1   | wire: 1ch)                |     |            |           |    |  |   |
|           | μ. Β/ 60030 | 24 K 10 00 K | 2011  |        |       |     |       |        | 2ch   | 3ch (time-<br>division    | 68  | 1.8 V      |           |    |  |   |
|           |             |              |       |        |       |     |       |        |       | UART: 1ch)                |     |            |           |    |  |   |
|           | μPD78058F   | 48 K to 60 K |       |        |       |     |       |        |       | 3ch                       | 69  | 2.7 V      |           |    |  |   |
|           | μPD78054    | 16 K to 60 K |       |        |       |     |       |        |       | (UART: 1ch)               |     | 2.0 V      |           |    |  |   |
|           | µPD780034   | 8 K to 32 K  |       |        |       |     | -     | 8ch    | -     | 3ch (UART:                | 51  | 1.8 V      |           |    |  |   |
|           | μPD780024   |              |       |        | i     |     | 8ch   | -      |       | 1ch, time-<br>division 3- |     |            |           |    |  |   |
|           |             |              |       |        |       |     |       |        |       |                           |     | wire: 1ch) |           |    |  |   |
|           | μPD780964   |              | 3ch   | Note   | -     |     | _     | 8ch    |       | 2ch                       | 47  | 2.7 V      |           |    |  |   |
|           | µPD780924   |              |       | _      |       |     | 8ch   | -      |       | (UART: 2ch)               |     |            |           |    |  |   |
|           | μPD78014H   |              | 2ch   | 1ch    | 1ch   |     |       |        |       | 2ch                       | 53  | 1.8 V      |           |    |  |   |
|           | µPD78018F   | 8 K to 60 K  |       |        |       |     |       |        |       |                           |     |            |           |    |  |   |
|           | µPD78014    | 8 K to 32 K  |       |        |       |     |       |        |       |                           |     | 2.7 V      |           |    |  |   |
|           | µPD780001   | 8 K          |       | -      | -     |     |       |        |       | 1ch                       | 39  |            | -         |    |  |   |
|           | μPD78002    | 8 K to 16 K  |       |        | 1ch   |     | -     |        |       |                           |     |            |           | 53 |  | 2 |
|           | µPD78083    |              |       |        | 1     |     | 8ch   |        |       | 1ch<br>(UART: 1ch)        | 33  | 1.8 V      | -         |    |  |   |
| FIP drive | µPD780208   | 32 K to 60 K | 2ch   | 1ch    | 1ch   | 1ch | 8ch   | _      | -     | 2ch                       | 74  | 2.7 V      |           |    |  |   |
|           | µPD78044F   | 16 K to 40 K |       |        |       |     |       |        |       |                           | 68  |            |           |    |  |   |
|           | μPD78024    | 24 K to 32 K |       |        |       |     |       |        |       |                           | 54  |            |           |    |  |   |
| LCD       | µPD780308   | 48 K to 60 K | 2ch   | 1ch    | 1ch   | 1ch | 8ch   | -      | -     | 3ch (time-                | 57  | 1.8 V      | -         |    |  |   |
| drive     |             |              |       |        |       |     |       |        |       | division                  |     |            |           |    |  |   |
|           | DD70004D    |              |       |        |       | -   |       |        |       | UART: 1ch)                |     |            |           |    |  |   |
|           | μPD78064B   | 32 K         |       |        |       |     |       |        |       | 2ch<br>(UART: 1ch)        |     | 2.0 V      |           |    |  |   |
| IEBus     | μPD78064    | 16 K to 32 K |       |        |       |     |       |        |       |                           |     |            |           |    |  |   |
|           | μPD78098    | 32 K to 60 K | 2ch   | 1ch    | 1ch   | 1ch | 8ch   | -      | 2ch   | 3ch<br>(UART: 1ch)        | 69  | 2.7 V      | V         |    |  |   |
|           | µPD78P0914  | 32 K         | 6ch   | -      | -     | 1ch | 8ch   | -      | -     | 2ch                       | 54  | 4.5 V      | ×         |    |  |   |

The following shows the major differences among subseries products.

Note 10-bit timer: 1 channel

🖬 6427525 0099467 OOT 🛤

7

.....

#### 1.6 Block Diagram



Remarks 1. The internal ROM and RAM capacities differ depending on the product.
2. (): μPD78F0924, 78F0964

🖬 6427525 0099468 T46 🔜

. . . . ... ....

Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### 1.7 Functional Outline

.

| ltem                | Product Name            | μΡD780921<br>μΡD780961                                                                                                                                                                                                                            | μΡD780922<br>μΡD780962                    | μΡD780923<br>μΡD780963 | μPD780924<br>μPD780964 | μPD78F0924<br>μPD78F0964              |  |  |  |  |  |
|---------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|------------------------|------------------------|---------------------------------------|--|--|--|--|--|
| Internal            | ROM capacity            | 8 Kbytes                                                                                                                                                                                                                                          | 16 Kbytes                                 | 24 Kbytes              | 32 Kbytes              | 32 Kbytes                             |  |  |  |  |  |
| memory              | ROM structure           | Mask ROM                                                                                                                                                                                                                                          | <u> </u>                                  | 1                      | 1                      | Flash memory                          |  |  |  |  |  |
|                     | High-speed RAM capacity | 512 bytes                                                                                                                                                                                                                                         |                                           |                        |                        |                                       |  |  |  |  |  |
| Memory spa          | ace                     | 64 Kbytes                                                                                                                                                                                                                                         |                                           | ·                      |                        |                                       |  |  |  |  |  |
| General-pu          | rpose register          | 8 bits x 32 registe                                                                                                                                                                                                                               | rs (8 bits × 8 regis                      | ters × 4 banks)        |                        | ·····                                 |  |  |  |  |  |
| Instruction         | cycle                   | •                                                                                                                                                                                                                                                 | n execution time v<br>.96 μs/1.9 μs/3.8 μ |                        | eration with system    | n clock)                              |  |  |  |  |  |
| Instruction         | set                     | <ul> <li>16-bit operation</li> <li>Multiply/divide (8 bits × 8 bits, 16 bits + 8 bits)</li> <li>Bit manipulate (set, reset, test, Boolean operation)</li> <li>BCD adjust, etc.</li> </ul>                                                         |                                           |                        |                        |                                       |  |  |  |  |  |
| I/O ports           |                         | Total         : 47           • CMOS inputs         8           • CMOS I/Os         : 39                                                                                                                                                           |                                           |                        |                        |                                       |  |  |  |  |  |
| Real-time o         | output ports            | 8 bits x 1 or 4 bits x 2                                                                                                                                                                                                                          |                                           |                        |                        |                                       |  |  |  |  |  |
| A/D conver          | ter                     | <ul> <li>8-bit resolution × 8 channels (μPD780921, 780922, 780923, 780924, 78F0924)</li> <li>10-bit resolution × 8 channels (μPD780961, 780962, 780963, 780964, 78F0964)</li> <li>Power supply voltage: AV<sub>DD</sub> = 2.7 to 5.5 V</li> </ul> |                                           |                        |                        |                                       |  |  |  |  |  |
| Serial interf       | ace                     | UART × 2 channels                                                                                                                                                                                                                                 |                                           |                        |                        |                                       |  |  |  |  |  |
| Timer               |                         | 8-bit timer/event counter : 3 channels     10-bit inverter control timer : 1 channel     Watchdog timer : 1 channel                                                                                                                               |                                           |                        |                        |                                       |  |  |  |  |  |
| Timer outpu         | Jt                      | 9 (8-bit PWM output x 3, and inverter control output x 6)                                                                                                                                                                                         |                                           |                        |                        |                                       |  |  |  |  |  |
| Vectored            | Maskable                | Internal: 12, external: 4                                                                                                                                                                                                                         |                                           |                        |                        |                                       |  |  |  |  |  |
| interrupt<br>source | Non-maskable            | Internal: 1                                                                                                                                                                                                                                       |                                           |                        |                        | · · · · · · · · · · · · · · · · · · · |  |  |  |  |  |
| Software 1          |                         |                                                                                                                                                                                                                                                   |                                           |                        |                        |                                       |  |  |  |  |  |
| Power supp          | oly voltage             | Vpp = 2.7 to 5.5 V                                                                                                                                                                                                                                |                                           |                        |                        |                                       |  |  |  |  |  |
| Operating a         | mbient temperature      | $T_{A} = -40 \text{ to } +85 \text{ °C}$                                                                                                                                                                                                          |                                           |                        |                        |                                       |  |  |  |  |  |
| Package             |                         | <ul> <li>64-pin plastic sh</li> <li>64-pin plastic Ql</li> </ul>                                                                                                                                                                                  | rink DIP (750 mil)<br>FP (14 × 14 mm)     |                        |                        |                                       |  |  |  |  |  |

6427525 0099469 982

10

# PAGE(S) INTENTIONALLY BLANK

| 6427525 0099470 6T4 🖿

Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### 2.1 List of Pin Functions

#### (1) Port pins

| Pin Name   | 1/0   | Function                                                       | After Reset | Alternate<br>Function |
|------------|-------|----------------------------------------------------------------|-------------|-----------------------|
| P00        | 1/0   | Port 0                                                         | Input       | INTP0/TOFF7           |
| P01        |       | 4-bit I/O port                                                 |             | INTP1                 |
| P02        |       | Input/output can be specified bit-wise.                        |             | INTP2                 |
| P03        | 1     | When used as an input port, an on-chip pull-up resistor can be |             | INTP3/ADTRG           |
|            |       | connected by software.                                         |             |                       |
| P10 to P17 | Input | Port 1                                                         | Input       | ANIO to ANI7          |
|            |       | 8-bit input only port                                          |             |                       |
| P20        | 1/0   | Port 2                                                         | Input       | RxD00                 |
| P21        | 7     | 7-bit I/O port                                                 |             | TxD00                 |
| P22        |       | Input/output can be specified bit-wise.                        |             | RxD01                 |
| P23        | ]     | When used as an input port, an on-chip pull-up resistor can be |             | TxD01                 |
| P24        |       | connected by software.                                         |             | T150/TO50             |
| P25        | -     |                                                                |             | TI51/TO51             |
| P26        |       |                                                                |             | T152/TO52             |
| P30 to P37 | 1/0   | Port 3                                                         | Input       | RTP0 to RTP7          |
|            |       | 8-bit I/O port                                                 |             |                       |
|            |       | Input/output can be specified bit-wise.                        |             |                       |
|            |       | When used as an input port, an on-chip pull-up resistor can be |             |                       |
|            |       | connected by software.                                         |             |                       |
| P40 to P47 | 1/0   | Port 4                                                         | Input       | AD0 to AD7            |
|            | 1     | 8-bit I/O port                                                 |             |                       |
|            |       | Input/output can be specified bit-wise.                        |             |                       |
|            |       | When used as an input port, an on-chip pull-up resistor can be |             |                       |
|            |       | connected by software.                                         |             |                       |
| P50 to P57 | 1/0   | Port 5                                                         | Input       | A8 to A15             |
|            |       | 8-bit I/O port                                                 |             |                       |
|            |       | Input/output can be specified bit-wise.                        |             |                       |
|            |       | LEDs can be driven directly.                                   |             |                       |
|            |       | When used as an input port, an on-chip pull-up resistor can be |             |                       |
|            |       | connected by software                                          |             |                       |
| P64        | 1/0   | Port 6                                                         | Input       | RD                    |
| P65        | ]     | 4-bit I/O port                                                 |             | WR                    |
| P66        | ]     | Input/output can be specified bit-wise.                        |             | WAIT                  |
| P67        |       | When used as an input port, an on-chip pull-up resistor can be |             | ASTB                  |
|            |       | connected by software.                                         |             |                       |

🔲 6427525 0099471 530 🔳

.

Powered by ICminer.com Electronic-Library Service CopyRight 2003

## (2) Pins other than port pins

- -----

| Pin Name            | 1/0    | Function                                                             | After Reset           | Alternate<br>Function |
|---------------------|--------|----------------------------------------------------------------------|-----------------------|-----------------------|
| INTPO               | Input  | External interrupt input that can specify the effective edge         | Input                 | P00/TOFF7             |
| INTP1               |        | (rising edge, falling edge, or both rising and falling edges) can be | Input                 | P01                   |
| INTP2               |        | specified.                                                           | Input                 | P02                   |
| INTP3               | ]      |                                                                      | Input                 | P03/ADTRG             |
| T150                | Input  | External count clock input to timer (TM50)                           | Input                 | P24/TO50              |
| TI51                |        | External count clock input to timer (TM51)                           | Input                 | P25/T051              |
| TI52                |        | External count clock input to timer (TM52)                           | Input                 | P26/T052              |
| TO50                | Output | Timer (TM50) output                                                  | Input                 | P24/T150              |
| TO51                | 1      | Timer (TM51) output                                                  | Input                 | P25/TI51              |
| TO52                | 1      | Timer (TM52) output                                                  | Input                 | P26/T152              |
| RTP0 to RTP7        | Output | Real-time output port that outputs pulses in synchronization with    | Input                 | P30 to P37            |
|                     |        | trigger signals outputs from the real-time pulse unit.               |                       |                       |
| TxD00               | Output | Asynchronous serial interface serial data output                     | Input                 | P21                   |
| TxD01               | 1      |                                                                      | Input                 | P23                   |
| RxD00               | Input  | Asynchronous serial interface serial data input                      | Input                 | P20                   |
| RxD01               | 1      |                                                                      | Input                 | P22                   |
| ANIO to ANI7        | Input  | A/D converter analog input                                           | Input                 | P10 to P17            |
| ADTRG               | Input  | External trigger signal input to the A/D converter                   | Input                 | P03/INTP3             |
| TO70 to TO75        | Output | Timer output for the 3-phase PWM inverter control                    | Hi-Z                  | -                     |
| TOFF7               | Input  | Timer output (TO70 to TO75) stop interrupt input                     | Input                 | P00/INTP0             |
| AD0 to AD7          | 1/0    | Lower address/data bus when memory is expanded externally            | Input                 | P40 to P47            |
| A8 to A15           | Output | Upper address bus when memory is expanded externally                 | Input                 | P50 to P57            |
| RD                  | Output | Strobe signal output for external memory read operation              | Input                 | P64                   |
| WA                  |        | Strobe signal output for external memory write operation             | Input                 | P65                   |
| WAIT                | Input  | Wait insertion when accessing external memory                        | Input                 | P66                   |
| ASTB                | Output | Strobe output that externally latches address information output     | Input                 | P67                   |
|                     |        | to ports 4 and 5 to access external memory                           |                       |                       |
| AVREF               | Input  | A/D converter reference voltage input                                |                       |                       |
| AVDD                | -      | A/D converter analog power supply. Connect to Voto                   |                       |                       |
| AVss                | _      | A/D converter ground potential. Connect to Vsso                      |                       |                       |
| RESET               | Input  | System reset input                                                   |                       |                       |
| K1                  | Input  | Crystal connection for system clock oscillation                      |                       |                       |
| K2                  | _      |                                                                      | <u>├</u> ─── <u>↓</u> |                       |
| 000                 | -      | Positive power supply for ports                                      |                       |                       |
| /sso                | -      | Ground potential for ports                                           | _                     | <u> </u>              |
| /001                | -      | Positive power supply except for ports                               |                       |                       |
| /ss1                | +      | Ground potential except for ports                                    | -                     |                       |
| EST                 | -      | Test mode set pin. Connect to Vsso directly                          |                       |                       |
| /pp <sup>Nete</sup> | -      | High-voltage application for program write/verify. Directly connect  |                       |                       |
|                     |        | this pin to Vsso in normal mode.                                     | -                     | -                     |

Note µPD78F0924, 78F0964 only

12

Powered by ICminer.com Electronic-Library Service CopyRight 2003

......

🔳 6427525 0099472 477 🔳

-----

## 2.2 Description of Pin Functions

#### 2.2.1 P00 to P03 (Port0)

These pins constitute a 4-bit I/O port, port 0. In addition, these pins are also used to input external interrupt signals, a timer output stop interrupt signal and an external trigger signal of the A/D converter.

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

### (1) Port mode

In this mode, P00 to P03 function as 4-bit input/output port pins.

Port 0 can be set in the input or output port mode in 1-bit units by using port mode register 0. When these pins are used as an input port, an internal pull-up resistor can be used if so specified by the pull-up resistor option register.

## (2) Control mode

In this mode, P00 to P03 are used to input external interrupts, a timer output stop interrupt, and an external trigger signal of the A/D converter.

### (a) INTP0 to INTP3

These pins are external interrupt input pins for which valid edge can be specified (rising edge, falling edge, and both rising and falling edges). INTP2 also functions as an external trigger signal input pin of the real-time output port when a valid edge is input.

#### (b) TOFF7

Timer output (TO70 to TO75) stop interrupt input pin

### (c) ADTRG

External trigger signal input pin of the A/D converter

#### 2.2.2 P10 to P17 (Port1)

These pins constitute an 8-bit input port, port1. In addition to the general-purpose port function, these pins also serve as the analog input pins of the A/D converter.

## (1) Port mode

In this mode, P10 to P17 function as 8-bit input port pins.

### (2) Control mode

In this mode, P10 to P17 function as the analog input pins (ANI0 through ANI7) of the A/D converter.



#### 2.2.3 P20 to P26 (Port2)

These pins constitute an 7-bit I/O port, port 2. In addition, these pins are also used to input/output the data of the serial interface, input/output timer.

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

### (1) Port mode

In the port mode, P20 and P27 function as an 7-bit I/O port. Port 2 can be set in the input or output mode in 1-bit units by using the port mode register 2. When the port is used as an input port, an internal pull-up resistor can be used if so specified by the pull-up resistor option register.

#### (2) Control mode

In this mode, P20 to P27 input/output the data of the serial interface, input/output timer.

#### (a) RxD00, RxD01, TxD00, TxD01

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

### (b) TI50 to TI52

External count clock input pins of the 8-bit timer/event counter.

### (c) TO50 to TO52

Timer output pins.

### 🛛 6427525 0099474 24T 📰

Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### 2.2.4 P30 to P37 (Port3)

These pins constitute an 8-bit I/O port, port 3. In addition, they also functions as a real-time output port. Port 3 can be set in the following operation modes in 1-bit units.

### (1) Port mode

In this mode, port 3 functions as an 8-bit I/O port which can be set in the input or output mode in 1-bit units by using the port mode register 3. When used as an input port, an internal pull-up resistor can be used if so specified by the pull-up resistor option register.

### (2) Control mode

In this mode, the pins of port 3 can be used as a real-time output port (RTP0 through RTP7) that outputs data in synchronization with a trigger.

#### 2.2.5 P40 to P47 (Port4)

These pins form an 8-bit I/O port, port 4. In addition, they also form an address/data bus. This port can be set in the following operation modes in 1-bit units.

#### (1) Port mode

In this mode, P40 to P47 function as an 8-bit I/O port which can be set in the input or output mode in 1-bit units by using the port mode register 4. When used as an input port, an internal pull-up resistor can be used if so specified by the pull-up resistor option register.

## (2) Control mode

In this mode, P40 to P47 function as the lower address/data bus pins (AD0 through AD7) in the external memory extension mode. The pins used as address/data bus pins are automatically disconnected from the internal pull-up resistor.

## 6427525 0099475 186 📟

### 2.2.6 P50 to P57 (Port5)

These pins form an 8-bit I/O port, port 5, which also serves as an address bus. These pins can directly drive LEDs.

Port 5 can be set in the following operation modes in 1-bit units.

### (1) Port mode

In this mode, P50 to P57 constitute an 8-bit I/O port which can be set in the input or output mode in 1-bit units by using the port mode register 5. When used as an input port, an internal pull-up resistor can be used if so specified by the pull-up resistor option register.

#### (2) Control mode

In this mode, P50 to P57 function as the higher address bus pins (A8 to A15) in the external memory extension mode. The pins used as address bus pins are automatically disconnected from the internal pull-up resistor.

#### 2.2.7 P64 to P67 (Port6)

These pins constitute an 4-bit I/O port, port 6, which can be also used to output control signals in the external memory extension mode.

Port 6 can be set in the following operation modes in 1-bit units.

#### (1) Port mode

In this mode, P60 to P67 constitute an 4-bit I/O port, which can be set in the input or output mode in 1-bit units by using the port mode register 6.

When using P64 to P67 as input port pins, an internal pull-up resistor can be used if so specified by the pullup resistor option register.

### (2) Control mode

In this mode, P60 to P67 functions as control signal output pins ( $\overline{RD}$ ,  $\overline{WR}$ ,  $\overline{WAIT}$ , and ASTB) in the external memory extension mode. The pins used as control signal output pins are automatically disconnected from the internal pull-up resistor.

## 2.2.8 TO70 to TO75

These are the timer output pins for the 3-phase PWM inverter control.

### 2.2.9 AVREF

This pin inputs a reference voltage to the A/D converter. Connect this pin to Vsso when the A/D converter is not used.

## 2.2.10 AVDD

This is the analog power supply pin of the A/D converter.

Keep this pin at the same voltage as the Voo pin even when the A/D converter is not used.

### 2.2.11 AVss

This is the ground pin of the A/D converter.

Keep this pin at the same voltage as the Vsso pin even when the A/D converter is not used.

#### ■ 6427525 0099476 0**1**2 ■

Caution If the external wait state is not used in the external memory extension mode, P66 can be used as an I/O port pin.

## 2.2.12 RESET

This pin inputs an active-low system reset signal.

## 2.2.13 X1 and X2

These pins are used to connect a crystal resonator for system clock oscillation.

To supply an external clock, input the clock to X1 and input the inverted signal to X2.

## 2.2.14 VDD0, VDD1

Voto is the positive power supply pin for ports. Voto is the positive power supply pin for blocks other than ports.

## 2.2.15 Vsso, Vss1

Vsso is the ground pin for ports. Vss1 is the ground pin for blocks other than ports.

## 2.2.16 Vpp (µPD78F0924, 78F0964 only)

A high voltage should be applied to this pin when the program is written or verified. Directly connect this pin to Vsso in the normal operation mode.

## 2.2.17 TEST (mask ROM model only)

Pin used or IC testing. Must be directly connected to Vsso.

## 2.3 Recommended Connection of Unused Pins

The recommended connections of unused pins are shown in Table 2-1.

| Pin Name                   | 1/0    | Recommended Connection of Unused Pins                |
|----------------------------|--------|------------------------------------------------------|
| P00/INTP0/TOFF7            | 1/0    | Individually connect to Vsso via a resistor.         |
| P01/INTP1                  | 1      |                                                      |
| P02/INTP2                  |        |                                                      |
| P03/INTP3/ADTRG            |        |                                                      |
| P10/ANI0 to P17/ANI7       | Input  | Individually connect to VDD0 or Vsso via a resistor. |
| P20/RxD00                  | 1/0    |                                                      |
| P21/TxD00                  |        |                                                      |
| P22/RxD01                  |        |                                                      |
| P23/TxD01                  |        |                                                      |
| P24/T150/TO50              |        |                                                      |
| P25/TI51/TO51              |        |                                                      |
| P26/TI52/TO52              |        |                                                      |
| P30/RTP0 to P37/RTP7       |        |                                                      |
| P40/AD0 to P47/AD7         |        |                                                      |
| P50/A8 to P57/A15          |        |                                                      |
| P64/RD                     |        |                                                      |
| P65/WR                     |        |                                                      |
| P66/WAIT                   |        |                                                      |
| P67/ASTB                   |        |                                                      |
| TO70 to TO75               | Output | Open                                                 |
| AVod                       | -      | Connect to Voo.                                      |
| AVREF                      | Ì      | Connect to Vsso.                                     |
| AVss                       |        | •                                                    |
| TEST (Mask ROM Version)    | Ī      | Connect to Vsso directly.                            |
| Ver (Flash memory version) |        |                                                      |

| Table 2-1. | Recommended | Connection o | f Unused Pins |
|------------|-------------|--------------|---------------|
|            |             |              |               |

🖬 6427525 0099478 995 페

## CHAPTER 3 CPU ARCHITECTURE

### 3.1 Memory Space

Each model in the  $\mu$ PD780924, 780964 subseries can access a memory space of 64 Kbytes. Figures 3-1 to 3-5 show memory maps of the respective models.

Caution The initial value of the memory size select register (IMS) is fixed (to CFH) for all the models in the  $\mu$ PD780924 and 780964 subseries, regardless of the capacity of the internal memory. Therefore, set the value specified for each model to this register.

| μ <b>PD780921, 780961</b> | : 42H                                             |
|---------------------------|---------------------------------------------------|
| μ <b>PD780922, 780962</b> | : 44H                                             |
| μPD780923, 780963         | : C6H                                             |
| μPD780924, 780964         | : C8H                                             |
| μPD78F0924, 78F0964       | : Value corresponding to those of mask ROM models |



Figure 3-1. Memory Map (µPD780921, 780961)

🛚 6427525 0099479 821 📟

.





## | 64275250099480543 **||||**





## 🛚 6427525 0099481 48T 🖿





6427525 0099482 316 📟





# 🛚 6427525 0099483 252 🖿

#### 3.1.1 Internal program memory space

The internal program memory space stores programs and table data. This space is usually addressed by the program counter (PC).

Each model in the  $\mu$ PD780924, 780964 subseries is provided with the following internal ROM (or flash memory):

| Part Number         | Capacity     |                                 |  |  |
|---------------------|--------------|---------------------------------|--|--|
|                     | Structure    |                                 |  |  |
| μPD780921, 780961   | Mask ROM     | 8192 × 8 bits (0000H to 1FFFH)  |  |  |
| μPD780922, 780962   |              | 16384 × 8 bits (0000H to 3FFFH) |  |  |
| μPD780923, 780963   |              | 24576 × 8 bits (0000H to 5FFFH) |  |  |
| μPD780924, 780964   | -            | 32768 × 8 bits (0000H to 7FFFH) |  |  |
| μPD78F0924, 78F0964 | flash memory | 32768 × 8 bits (0000H to 7FFFH) |  |  |

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

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

#### (1) Vector table area

A 64-byte area of addresses 0000H to 003FH is reserved as a vector table area. This area stores program start addresses to which execution branches when the RESET signal is input or when an interrupt request is generated. Of a 16-bit program start address, the lower 8 bits are stored in an even address, and the higher 8 bits are stored in an odd address.

| Vector Table Address | Interrupt Request | Vector Table Address | Interrupt Request |  |  |
|----------------------|-------------------|----------------------|-------------------|--|--|
| 0000н                | RESET input       | 0014H                | INTST0            |  |  |
| 0004H                | INTWDT            | 0016H                | INTSER1           |  |  |
| 0006H                | INTP0             | 0018H                | INTSR1            |  |  |
| 0008H                | INTP1             | 001AH                | INTST1            |  |  |
| 000AH                | INTP2             | 001CH                | INTTM50           |  |  |
| 000CH                | INTP3             | 001EH                | INTTM51           |  |  |
| 000EH                | INTTM7            | 0020H                | INTTM52           |  |  |
| 0010H                | INTSERO           | 0022H                | INTAD0            |  |  |
| 0012H                | INTSRO            | 003EH                | BRK instruction   |  |  |

#### Table 3-2. Vector Table

### (2) CALLT instruction table area

In a 64-byte area of addresses 0040H to 007FH, the subroutine entry address of a 1-byte call instruction (CALLT) can be stored.

### (3) CALLF instruction entry area

From an area of addresses 0800H to 0FFFH, a subroutine can be directly called by using a 2-byte call instruction (CALLF).

24

### 6427525 0099484 199 🖿

## 3.1.2 Internal data memory space

The  $\mu$ PD780924 and 780964 subseries are provided with the following internal high-speed RAM.

| Part Number         | Internal High-Speed RAM        |
|---------------------|--------------------------------|
| μPD780921, 780961   | 512 x 8 bits (FD00H to FEFFH)  |
| μPD780922, 780962   |                                |
| μPD780923, 780963   | 1024 x 8 bits (FB00H to FEFFH) |
| μPD780924, 780964   |                                |
| μPD78F0924, 78F0964 |                                |

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

A 32-byte area of addresses FEE0H to FEFFH is assigned four banks of general registers. Each bank consists of eight 8-bit registers.

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

### 3.1.3 Special function register (SFR) area

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

Caution Do not access an address to which no SFR is allocated.

#### 3.1.4 External memory space

This is an external memory space that can be accessed by using the memory extension mode register (MM). This space can store programs and table data, and can be assigned peripheral devices.



#### 3.2 Processor Registers

The  $\mu$ PD780924, 780964 subseries are provided with the following processor registers:

#### 3.2.1 Control registers

Each of these registers has a dedicated function such as to control the program sequence, status, and stack memory. The control registers include the program counter, program status word, and stack pointer.

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

The program counter is a 16-bit register that holds an address of the program to be executed next. The contents of this register are automatically incremented according to the number of bytes of an instruction to be fetched when a normal operation is performed. When a branch instruction is executed, immediate data or the contents of a register is set to the program counter.

When the RESET signal is input, the value of the reset vector table at addresses 0000H and 0001H is set to the program counter.





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

The program status word is an 8-bit register consisting of flags that are set or reset as a result of instruction execution.

The contents of the program status word are automatically pushed to the stack when an interrupt request is generated or when the PUSH PSW instruction is executed, and are automatically popped from the stack when the RETB, RETI, or POP PSW instruction is executed.

The contents of the program status word are set to 02H when the RESET signal is input.

Figure 3-7. Program Status Word Configuration

| 7  |   |      |    |      |   |     | 0  | _ |
|----|---|------|----|------|---|-----|----|---|
| IE | z | RBS1 | AC | RBS0 | 0 | ISP | CY |   |

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

This flag controls acknowledgement of an interrupt request by the CPU.

When this flag is reset to 0 (DI status), only the non-maskable interrupt can be acknowledged, and all the other interrupts are disabled.

When this flag is set to 1 (EI status), interrupts are enabled, and acknowledging interrupt requests is controlled by the in-service priority flag (ISP), interrupt mask flag corresponding to each interrupt source, and priority flag.

The IE flag is reset to 0 when the DI instruction is executed or when an interrupt acknowledged, and is set to 1 when the EI instruction is executed.

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

This flag is set to 1 when the result of an operation performed is 0; otherwise, it is reset to 0.

6427525 0099486 T61 🔳

Powered by ICminer.com Electronic-Library Service CopyRight 2003

# (c) Register bank select flags (RBS0 and RBS1)

These 2-bit flags select one of the four register banks.

Information of 2 bits that indicate the register bank selected by execution of the "SEL RBn" instruction is stored in these flags.

## (d) Auxiliary carry flag (AC)

This flag is set to 1 when a carry occurs from bit 3 or a borrow to bit 3 occurs as a result of an operation performed; otherwise, it is reset to 0.

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

This flag controls the priority of maskable vectored interrupts that can be acknowledged. When this flag is 0, acknowledgement of the vectored interrupt with the lower priority specified by the priority specification flag register (PR0L, PR0H) is disabled.

When it is 1, any interrupt is acknowledged regardless of its priority. Actually, acknowledging interrupts is controlled by the interrupt enable flag (IE).

## (f) Carry flag (CY)

This flag records an overflow or underflow that occurs as the result of executing an add or subtract instruction. It also records the value shifted out when a rotate instruction is executed. In addition, it also functions as a bit accumulator when a bit operation instruction is executed.

### (3) Stack pointer (SP)

This is a 16-bit register that holds the first address of the stack area in the memory. As the stack area, only the internal high-speed RAM area can be specified. The internal high-speed RAM area of each product is as follows:

| Part Number                       | Internal High-Speed RAM Area |  |  |  |  |
|-----------------------------------|------------------------------|--|--|--|--|
| μPD780921, 780961, 780922, 780962 | FD00H to FEFFH               |  |  |  |  |
| μPD780923, 780963, 780924, 780964 | FB00H to FEFFH               |  |  |  |  |
| μPD78F0924, 78F0964               |                              |  |  |  |  |

## Table 3-4. Internal High-Speed RAM Area

## Figure 3-8. Stack Pointer Configuration

| 15 | 0 |
|----|---|
| SP | · |
|    |   |

The contents of the stack pointer are decremented when data is written (saved) to the stack memory, and incremented when data are read (restored) from the stack memory.

The data saved/restored as a result of each stack operation are as shown in Figures 3-9 and 3-10.

Caution The contents of the SP become undefined when the RESET signal is input. Be sure to initialize the SP before executing an instruction.





## Figure 3-9. Data Saved to Stack Memory





### 📕 6427525 0099488 834 📕

## 3.2.2 General-purpose registers

General-purpose registers are mapped to the specific addresses of the data memory (FEE0H to FEFFH). Four banks of general-purpose registers, each consisting of eight 8-bit registers (X, A, C, B, E, D, L, and H) are available.

Each register can be used as an 8-bit register. Moreover, two 8-bit registers can be used as a register pair, which are 16-bit registers (AX, BC, DE, and HL).

Each register can be described not only in function name (X, A, C, B, E, D, L, H, AX, BC, DE, or HL) but also in absolute name (R0 to R7, RP0 to RP3).

The register bank used for instruction execution is set by the CPU control instruction (SEL RBn). Because four register banks are provided, an efficient program can be developed by using one register bank for ordinary processing and another bank for interrupt processing.

| Bank Name | Reg              | ister            | Absolute |           | Reg              | ister | Absolute |
|-----------|------------------|------------------|----------|-----------|------------------|-------|----------|
|           | Function<br>Name | Absolute<br>Name | Address  | Bank Name | Function<br>Name |       |          |
|           | н                | R7               | FEFFH    |           | н                | R7    | FEEFH    |
|           | L                | R6               | FEFEH    |           | L                | R6    | FEEEH    |
|           | D                | R5               | FEFDH    |           | D                | R5    | FEEDH    |
| BANK0     | E                | R4               | FEFCH    | BANK2     | E                | R4    | FEECH    |
|           | В                | R3               | FEFBH    | DAINNZ    | В                | R3    | FEEBH    |
|           | С                | R2               | FEFAH    |           | С                | R2    | FEEAH    |
|           | A                | R1               | FEF9H    |           | A                | R1    | FEE9H    |
|           | X                | R0               | FEF8H    |           | X                | R0    | FEE8H    |
|           | н                | R7               | FEF7H    |           | н                | R7    | FEE7H    |
|           | L                | R6               | FEF6H    |           | L                | R6    | FEE6H    |
|           | D                | R5               | FEF5H    |           | D                | R5    | FEE5H    |
| BANK1     | E                | R4               | FEF4H    | BANK3     | E                | R4    | FEE4H    |
|           | В                | R3               | FEF3H    |           | В                | R3    | FEE3H    |
|           | С                | R2               | FEF2H    |           | с                | R2    | FEE2H    |
|           | A                | R1               | FEF1H    |           | A                | R1    | FEE1H    |
|           | x                | R0               | FEFOH    |           | x                | R0    | FEE0H    |

Table 3-5. Absolute Addresses of General-Purpose Registers

#### 6427525 0099489 770 🖿

## Figure 3-11. General-Purpose Register Configuration

#### (a) Absolute name



## (b) Function name



30

🛚 6427525 0099490 492 🖿

# 3.2.3 Special function registers (SFRs)

Unlike the general-purpose registers, special function registers have their own functions and are allocated to an area of addresses FF00H to FFFFH.

The special function registers can also be manipulated in the same manner as the general-purpose registers by using operation, transfer, and bit manipulation instructions. The bit units in which one register is to be manipulated (1, 8, or 16 bits) differ from that of another register.

The bit unit for manipulation is specified as follows:

1-bit manipulation

A symbol reserved by the assembler is described as the operand (sfr.bit) of a 1-bit manipulation instruction. An address can also be specified.

8-bit manipulation

A symbol reserved by the assembler is described as the operand (sfr) of an 8-bit manipulation instruction. An address can also be specified.

16-bit manipulation

A symbol reserved by the assembler is described as the operand (sfrp) of a 16-bit manipulation instruction. To specify address, describe an even address.

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

Symbol

These symbols indicate the addresses of the internal special function registers.

They are reserved words for the RA78K/0 and defined by header file strbit.h for the CC78K/0. These symbols can be described as the operands of instructions when the RA78K/0 or ID78K0 is used.

• R/W

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

- R/W : Read/write
- R : Read only
- W : Write only
- Bit units for manipulation

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

At reset

Indicates the status of the special function register when the RESET signal is input.

6427525 0099491 329 🗖

| Address | Special Function Register (SFR) Name | Symbol |          | R/  | w   | Ad    | dress l | Jnit    | On Reset  |
|---------|--------------------------------------|--------|----------|-----|-----|-------|---------|---------|-----------|
|         |                                      |        |          |     |     | 1 bit | 8 bits  | 16 bits |           |
| FF00H   | Port 0                               | P0     | R/W      |     | 0   | 0     | -       | 00H     |           |
| FF01H   | Port 1                               | P1     | P1       |     |     | 0     | 0       | -       |           |
| FF02H   | Port 2                               | P2     |          | R/W |     | 0     | 0       | -       |           |
| FF03H   | Port 3                               | P3     | <u>-</u> |     |     | 0     | 0       | _       |           |
| FF04H   | Port 4                               | P4     |          | ]   |     | 0     | 0       | -       | Undefined |
| FF05H   | Port 5                               | P5     |          | ]   |     | 0     | 0       |         |           |
| FF06H   | Port 6                               | P6     |          |     |     | 0     | 0       | -       |           |
| FF08H   | 10-bit buffer register 0             | BFCM0  | BFCMOL   | R/W | R/W | -     | 0       | 0       | 000H      |
| FF09H   |                                      |        | -        |     | -   |       | -       |         |           |
| FFOAH   | 10-bit buffer register 1             | BFCM1  | BFCM1L   | R/W | R/W | -     | 0       | 0       |           |
| FFOBH   |                                      |        | -        |     | -   |       | _       |         |           |
| FFOCH   | 10-bit buffer register 2             | BFCM2  | BFCM2L   | R/W | R/W | -     | 0       | 0       |           |
| FFODH   |                                      |        | -        |     | -   | •     | -       |         |           |
| FFOEH   | 10-bit buffer register 3             | BFCM3  | BFCM3L   | R/W | R/W | -     | 0       | 0       | OFFH      |
| FFOFH   |                                      |        | -        | 1   | -   |       | -       |         |           |
| FF10H   | 8-bit compare register 50            | CR50   |          | R/W |     | -     | 0       | -       | Undefined |
| FF11H   | 8-bit compare register 51            | CR51   |          |     |     |       | 0       | -       |           |
| FF12H   | 8-bit timer counter 50               | TM5    | TM50     | R   |     | -     | 0       | 0       | 00H       |
| FF13H   | 8-bit timer counter 51               |        | TM51     |     |     | -     | 0       |         |           |
| FF14H   | 8-bit compare register 52            | CR52   |          | R/W |     | -     | 0       | -       | Undefined |
| FF15H   | 8-bit timer counter 52               | TM52   |          | R   |     | -     | 0       | -       | 00H       |
| FF16H   | A/D conversion result register       | ADCR0  | ADCROL   |     |     | -     | -       | Note    | Undefined |
| FF17H   |                                      |        | ADCR0H   |     |     | -     | ONote   |         |           |
| FF18H   | Transmit shift register 0            | TXS00  |          | w   |     | -     | 0       | -       | FFH       |
|         | Receive buffer register 0            | RXB00  |          | R   |     | -     | 0       | -       |           |
| FF1AH   | Transmit shift register 1            | TXS01  |          | w   |     | -     | 0       | -       |           |
|         | Receive buffer register 1            | RXB01  |          | R   |     | -     | 0       | -       |           |
| FF20H   | Port mode register 0                 | PM0    |          | R/W |     | 0     | 0       | -       |           |
| FF22H   | Port mode register 2                 | PM2    |          |     |     | 0     | 0       | -       |           |
| FF23H   | Port mode register 3                 | РМЗ    |          |     | [   | 0     | 0       | -       | ļ         |
| FF24H   | Port mode register 4                 | PM4    |          |     |     | 0     | 0       | -       |           |
| FF25H   | Port mode register 5                 | PM5    |          |     | [   | 0     | 0       | -       |           |
| FF26H   | Port mode register 6                 | PM6    |          |     |     | 0     | 0       | -       |           |

### Table 3-6. Special Function Register List (1/3)

Note Use ADCR0 when the A/D conversion result register is accessed. These registers of the µPD780924 subseries can be accessed only in 8-bit units. When ADCR0 is read, the value of FF17H can be read.

🔳 6427525 0099492 265 🔳

These registers of the  $\mu$ PD780964 subseries can be accessed only in 16-bit units and cannot be accessed in 8-bit units.

32

Powered by ICminer.com Electronic-Library Service CopyRight 2003

\_\_\_\_

| Address | Special Function Register (SFR) Name            | Symbol | R/W | Ad          | dress l | On Reset     |      |
|---------|-------------------------------------------------|--------|-----|-------------|---------|--------------|------|
|         |                                                 |        |     | 1 bit       | 8 bits  | 16 bits      |      |
| FF30H   | Pull-up resistor option register 0              | PU0    | R/W | 0           | 0       | -            | 00H  |
| FF32H   | Pull-up resistor option register 2              | PU2    |     | 0           | 0       | -            |      |
| FF33H   | Pull-up resistor option register 3              | PU3    |     | 0           | 0       | -            |      |
| FF34H   | Pull-up resistor option register 4              | PU4    |     | 0           | 0       | -            |      |
| FF35H   | Pull-up resistor option register 5              | PU5    |     | 0           | 0       | -            |      |
| FF36H   | Pull-up resistor option register 6              | PU6    |     | 0           | 0       | -            |      |
| FF42H   | Watchdog timer clock select register            | WDCS   |     | _           | 0       | -            |      |
| FF47H   | Memory extension mode register                  | MEM    |     | 0           | 0       | -            |      |
| FF48H   | External interrupt rising edge enable register  | EGP    |     | 0           | 0       | -            |      |
| FF49H   | External interrupt falling edge enable register | EGN    |     | 0           | 0       | -            |      |
| FF68H   | 8-bit timer mode control register 50            | TMC50  |     | 0           | 0       | -            | 04H  |
| FF69H   | Timer clock select register 50                  | TCL50  | _   | -           | 0       | -            | 00H  |
| FF70H   | 8-bit timer mode control register 51            | TMC51  | -   | 0           | 0       | -            | 04H  |
| FF71H   | Timer clock select register 51                  | TCL51  | 1   | -           | 0       | -            | 00H  |
| FF78H   | 8-bit timer mode control register 52            | TMC52  |     | 0           | 0       |              | 04H  |
| FF79H   | Timer clock select register 52                  | TCL52  |     | -           | 0       | -            | 00H  |
| FFBOH   | A/D converter mode register 0                   | ADMO   |     | 0           | 0       | _            |      |
| FF81H   | Analog input channel specification register 0   | ADS0   | -   | -           | 0       |              |      |
| FF84H   | Real-time output buffer register L              | RTBLO  |     | 0           | 0       |              |      |
| FF85H   | Real-time output buffer register H              | RTBH0  |     | 0           | 0       |              |      |
| FF86H   | Real-time output port mode register             | RTPM0  |     | 0           | 0       |              |      |
| FF87H   | Real-time output port control register          | RTPC0  | -   | 0           | 0       | -            |      |
| FF90H   | Inverter timer control register 7               | TMC7   | -1  | 0           | 0       | -            |      |
| FF91H   | Inverter timer mode register 7                  | TMM7   | 1   | 0           | 0       |              |      |
| FF92H   | 10-bit compare register 0                       | СМО    |     |             |         |              |      |
| FF93H   |                                                 |        |     |             | -       | 0            |      |
| FF94H   | 10-bit compare register 1                       | CM1    |     | -           |         |              |      |
| FF95H   | -                                               |        |     |             | -       | 0            |      |
| FF96H   | 10-bit compare register 2                       | CM2    | -   |             |         |              |      |
| FF97H   |                                                 |        |     |             | -       | 0            |      |
| FF98H   | 10-bit compare register 3                       | СМЗ    |     |             |         |              |      |
| FF99H   | · · · ·                                         |        |     | -           | -       | $\circ \mid$ | FFH  |
| FF9AH   | Dead time reload register                       | DTIME  | -   |             |         | _            |      |
| FFA0H   | Asynchronous serial interface mode register 0   | ASIMOO |     | <b>  </b>   | 0       |              | 0011 |
| FFA1H   | Asynchronous serial interface status register 0 | ASIS00 |     |             | 0       | -            | 00H  |
| FFA2H   | Baud rate generator control register 0          | BRGC00 | R/W | ┼ <u></u> - | 0       | -            |      |
| FFA4H   | Asynchronous serial interface mode register 1   | ASIM01 |     |             | 0       | -            |      |
| FFA5H   | Asynchronous serial interface status register 1 | ASIS01 | R   | 0           | 0       |              |      |
|         | Baud rate generator control register 1          | BRGC01 | R/W | -           | 0       | -            |      |

# Table 3-6. Special Function Register List (2/3)

🔲 6427525 0099493 LTL 📟

\_\_\_\_

- ...

Powered by ICminer.com Electronic-Library Service CopyRight 2003

| Address              | Special Function Register (SFR) Name           | Symbol |     | R/W | Address Unit |        |         | On Reset             |
|----------------------|------------------------------------------------|--------|-----|-----|--------------|--------|---------|----------------------|
|                      |                                                |        |     |     | 1 bit        | 8 bits | 16 bits |                      |
| FFD0H<br>to<br>FFDFH | External access area <sup>Note 1</sup>         |        |     |     | 0            | 0      | -       | Undefined            |
| FFEOH                | Interrupt request flag register OL             | IFOL   | IF0 |     | 0            | 0      | 0       | 00H                  |
| FFE1H                | Interrupt request flag register 0H             | IFOH   |     |     | 0            | 0      |         |                      |
| FFE4H                | Interrupt mask flag register OL                | MKOL   | мко |     | 0            | 0      | 0       | FFH                  |
| FFE5H                | Interrupt mask flag register 0H                | мкон   |     |     | 0            | 0      |         |                      |
| FFE8H                | Priority specification flag register 0L        | PROL   | PRO |     | 0            | 0      | 0       |                      |
| FFE9H                | Priority specification flag register 0H        | PROH   |     |     | 0            | 0      |         |                      |
| FFF0H                | Memory size select register                    | IMS    |     |     | -            | 0      | -       | CFH <sup>Note2</sup> |
| FFF8H                | Memory extension wait setting register         | ММ     | ММ  |     | 0            | 0      | -       | 10H                  |
| FFF9H                | Watchdog timer mode register                   | WDTM   |     |     | 0            | 0      | -       | 00H                  |
| FFFAH                | Oscillation stabilization time select register | OSTS   |     |     | _            | 0      | -       | 04H                  |
| FFFBH                | Processor clock control register               | PCC    | PCC |     | 0            | 0      | -       |                      |

### Table 3-6. Special Function Register List (3/3)

**Notes 1.** The external access area cannot be addressed in the SFR addressing mode. Access this area with an instruction that can specify an address with 16 bits.

2. The initial value of this register is CFH. Set the following value to this register of each model.

| μPD780921, 780961:   | 42H                                             |
|----------------------|-------------------------------------------------|
| μPD780922, 780962:   | 44H                                             |
| μPD780923, 780963:   | С6Н                                             |
| μPD780924, 780964:   | C8H                                             |
| μPD78F0924, 78F0964: | Value corresponding to those of mask ROM models |

🛤 6427525 0099494 038 📟

## 3.3 Addressing Instruction Address

An instruction address is determined by the contents of the program counter (PC). The contents of the PC is usually automatically incremented by the number of bytes of an instruction to be fetched (by 1 per byte) every time an instruction is excuted. When an instruction that causes program execution to branch is performed, the address information of the branch destination is set to the PC by means of the following addressing (for details of each instruction, refer to 78K/0 Series User's Manual - Instruction (IEU-1372)).

### 3.3.1 Relative addressing

### [Function]

The 8-bit immediate data (displacement value: jdisp8) of the instruction code is added to the first address of the next instruction, the resultant sum is transferred to the program counter (PC), and the program branches. The displacement value is treated as signed 2's complement data (-128 to +127), and bit 7 serves as a sign bit. This addressing is used when "BR \$addr16" instruction or conditional branch instruction is executed.

#### [Operation]



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

### 3.3.2 Immediate addressing

### [Function]

The immediate data in an instruction word is transferred to the program counter (PC), and execution branches. This addressing is used when the "CALL !addr16", "BR !addr16", or "CALLF !addr11" instruction is executed.

## [Operation]

When "CALL laddr16" or "BR laddr16" instruction is executed



When "CALLF !addr11" instruction is executed



**6427525 0099496 900** 

## 3.3.3 Table indirect addressing

## [Function]

The contents of a specific location table (branch destination address) addressed by the immediate data of bits 1 to 5 of an instruction code are transferred to the program counter (PC), and program execution branches. This addressing is used when the "CALLT [addr5]" instruction is executed.

### [Operation]



### 🔲 6427525 0099497 847 🖿

## 3.3.4 Register addressing

## [Function]

The contents of the register pair (AX) specified by an instruction word are transferred to the program counter (PC), and program execution branches.

This addressing is used when the "BR AX" instruction is executed.

## [Operation]



38

6427525 0099498 783 📟

# 3.4 Addressing of Operand Address

## 3.4.1 Data memory addressing

The  $\mu$ PD780924, 780964 subseries are provided with many addressing modes to facilitate manipulation of the memory. By using these addressing modes, special function registers (SFRs) and general-purpose registers can be addressed according to their own functions. Figures 3-12 to 3-16 illustrate the addressing of the data memory.





# 📕 6427525 0099499 6lT 🖿



Figure 3-13. Data Memory Addressing (µPD780922, 780962)

## | 6427525 0099500 161 🔳

Powered by ICminer.com Electronic-Library Service CopyRight 2003





🖬 6427525 0099501 OT8 📰



Figure 3-15. Data Memory Addressing (µPD780924, 780964)

## 🛛 6427525 0099502 T34 🖿

Powered by ICminer.com Electronic-Library Service CopyRight 2003

.



Figure 3-16. Data Memory Addressing (µPD78F0924, 78F0964)

## 6427525 0099503 970 📟

### 3.4.2 Implied addressing

## [Function]

This addressing is to automatically address a register that functions as an accumulator (A or AX) in the generalpurpose register area.

Of the instruction words of the  $\mu$ PD780924 and 780964 subseries, those that use implied addressing are as follows:

| Instruction | Register Specified by Implied Addressing                          |
|-------------|-------------------------------------------------------------------|
| MULU        | Register A to store multiplicand and register AX to store product |
| DIVUW       | Register AX to store dividend and quotient                        |
| ADJBA/ADJBS | Register A to store numeric value subject to decimal adjustment   |
| ROR4/ROL4   | Register A to store digit data subject to digit rotation          |

### [Operand Format]

No specific operand format is used because the operand format is automatically determined by an instruction.

### [Example]

MULU X

The product between registers A and X is stored in register AX as a result of executing a multiply instruction of 8 bits x 8 bits. In this operation, registers A and AX are specified by implied addressing.

6427525 0099504 807 🖿

\_...

-----

### 3.4.3 Register addressing

### [Function]

This addressing accesses as an operand a general-purpose register selected by the register specification code (Rn, RPn) in an instruction word from the register bank specified by the register bank select flags (RBS0 and RBS1).

Register addressing is used when an instruction that has the following operand format is executed. When an 8-bit register is specified, one of the eight registers is specified by 3 bits in the instruction code.

### [Operand Format]

| Representation | Description            |
|----------------|------------------------|
| r              | X, A, C, B, E, D, L, H |
| гр             | AX, BC, DE, HL         |

r and rp can be described not only in function name (X, A, C, B, E, D, L, H, AX, BC, DE, or HL) but also in absolute name (R0 to R7, RP0 to RP3).

### [Example]

MOV A, C; To select C register as r

Instruction code

0 1 1 0 0 0 1 0

INCW DE; To select DE register pair as rp

Instruction code

## 3.4.4 Direct addressing

## [Function]

This addressing is to address a memory area to be manipulated by using the immediate data in an instruction word as an operand address.

## [Operand Format]

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

## [Example]

MOV A, !FE00H; To specify FE00H as !addr16

| Instruction code | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 |
|------------------|---|---|---|---|---|---|---|---|
|                  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|                  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 |

46

🗰 6427525 0099506 68T 📟

## 3.4.5 Short direct addressing

## [Function]

This addressing directly addresses a memory area to be manipulated from a fixed space by using the 8-bit data in an instruction word.

This addressing is applicable to a 256-byte space of FE20H to FF1FH. The internal high-speed RAM is mapped to addresses FE20H to FEFFH, and special function registers (SFRs) are mapped to addresses FF00H to FF1FH. To the SFR area (FF00H to FF1FH) to which short direct addressing is applied, ports, and compare and capture registers of timer/event counters that are frequently accessed on program are mapped. These SFRs can be manipulated with a few bytes and clocks.

Bit 8 of the effective address is 0 if the 8-bit immediate data is in a range of 20H to FFH, and 1 if the data is in a range of 00H to 1FH.

## [Operand Format]

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



## [Example]

MOV FE30H, #50H; To specify FE30H as saddr and 50H as immediate data



## [Operation]

48



#### I 6427525 0099508 452 🎟

Powered by ICminer.com Electronic-Library Service CopyRight 2003

## 3.4.6 Special function register (SFR) addressing

## [Function]

This addressing is to address special function registers (SFRs) mapped to the memory by using an 8-bit immediate data in an instruction word.

This addressing is applied to a 240-byte space of FF00H to FFCFH and FFE0H to FFFFH. However, the SFRs mapped to an area of FF00H to FF1FH can also be accessed by means of short direct addressing.

## [Operand Format]

| Representation | Description                                                                                   |  |  |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------|--|--|--|--|--|
| sfr            | Special function register name                                                                |  |  |  |  |  |
| sfrp           | Name of special function register that can be manipulated in 16-bit units (even address only) |  |  |  |  |  |

## [Example]

MOV PM0, A: To select PM0 as sfr



[Operation]



## **6**427525 0099509 399 **m**

## 3.4.7 Register indirect addressing

## [Function]

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

## [Operand Format]

| Representation | Description |
|----------------|-------------|
|                | (DE], [HL]  |

#### [Example]

MOV A, [DE]; To select [DE] as register pair

#### [Operation]



#### 3.4.8 Based addressing

#### [Function]

This addressing is to address a memory area by using the result of adding 8-bit immediate data as offset data, to the contents of the HL register pair in an instruction word as a base register. The base register is selected from the register bank specified by the register bank select flags (RBS0 and RBS1). The addition is executed by extending the offset data to 16 bits as a positive number. A carry from the 16th bit is ignored. This addressing is used to address the entire memory space.

#### [Operand Format]

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

#### [Example]

MOV A, [HL+10H]; To specify 10H as byte

| Instruction code | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 0 |
|------------------|---|---|---|---|---|---|---|---|
|                  | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |

## 3.4.9 Based indexed addressing

#### [Function]

This addressing is to address a memory area by using the result of adding the contents of the B or C register specified in an instruction word to the HL register pair in an instruction word as a base register. The base register is selected from the register bank specified by the register bank select flags (RBS0 and RBS1). The addition is executed by extending the offset data to 16 bits as a positive number. A carry from the 16th bit is ignored. This addressing is used to address the entire memory space.

#### [Operand Format]

| Representation | Description        |  |  |  |  |
|----------------|--------------------|--|--|--|--|
| —              | [HL + B], [HL + C] |  |  |  |  |

#### [Example]

52

When MOV A, [HL+B]

| Instruction code 1 0 1 0 1 0 1 1 |                  |   |   |   |   |   |   |   |   |
|----------------------------------|------------------|---|---|---|---|---|---|---|---|
|                                  | Instruction code | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 |

6427525 0099512 983 🖿



#### 3.4.10 Stack addressing

#### [Function]

This addressing is to indirectly address the stack area by using the contents of the stack pointer (SP). This addressing is automatically used to save/restore register contents when the PUSH, POP, subroutine call, or return instruction is executed, or when an interrupt request is generated.

The stack addressing can access the internal high-speed RAM area only.

## [Example]

When PUSH DE is executed

|                  |   | _ |   |   |   |   | _ | - |
|------------------|---|---|---|---|---|---|---|---|
| Instruction code | 1 | 0 | 1 | 1 | 0 | 1 | 0 | 1 |
|                  |   |   |   |   |   |   |   |   |



54

PAGE(S) INTENTIONALLY BLANK



Powered by ICminer.com Electronic-Library Service CopyRight 2003

## 4.1 Functions of Ports

The  $\mu$ PD780924, 730964 subseries is provided with eight input port pins and 39 I/O port pins. Figure 4-1 shows these port pins. Each cort can be manipulated in 1-bit or 8-bit units and controlled in various ways. Moreover, some port pins also serve  $\approx$  the I/O pins of the internal hardware.



Figure 4-1. Types of Ports

6427525 0099515 692 🖿

| Pir    | n Name     | Function                                                                                                                                                                    | Shared by:   |
|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| Port 0 | P00        | 4-bit I/O port                                                                                                                                                              | INTP0/TOFF7  |
|        | P01        | Can be specified for input/output bitwise.                                                                                                                                  | INTP1        |
|        | P02        | When used as input port, internal pull-up resistor can be connected by software.                                                                                            | INTP2        |
|        | P03        |                                                                                                                                                                             | INTP3/ADTRG  |
| Port 1 | P10 to P17 | 8-bit input port                                                                                                                                                            | ANI0 to ANI7 |
| Port 2 | P20        | 7-bit I/O port                                                                                                                                                              | RxD00        |
|        | P21        | Can be specified for input/output bitwise.                                                                                                                                  | TxD00        |
|        | P22        | When used as input port, internal pull-up resistor can be connected by software.                                                                                            | RxD01        |
|        | P23        |                                                                                                                                                                             | TxD01        |
|        | P24        |                                                                                                                                                                             | T150/TO50    |
|        | P25        |                                                                                                                                                                             | TI51/TO51    |
|        | P26        |                                                                                                                                                                             | T152/TO52    |
| Port 3 | P30 to P37 | 8-bit I/O port<br>Can be specified for input/output bitwise.<br>When used as input port, internal pull-up resistor can be connected by software.                            | RTP0 to RTP7 |
| Port 4 | P40 to P47 |                                                                                                                                                                             | AD0 to AD7   |
| Port 5 | P50 to P57 | 8-bit I/O port<br>Can directly drive LED.<br>Can be specified for input/output bitwise.<br>When used as input port, internal pull-up resistor can be connected by software. | A8 to A15    |
| Port 6 | P64        | 4-bit I/O port                                                                                                                                                              | RD           |
|        | P65        | Can be specified for input/output bitwise.                                                                                                                                  | WR           |
|        | P66        | When used as input port, internal pull-up resistor can be connected by software.                                                                                            | WAIT         |
|        | P67        |                                                                                                                                                                             | ASTB         |

🖬 6427525 00995<u>1</u>6 529 📰

Table 4-1. Port Functions

-----

## 4.2 Port Configuration

A port consists of the following hardware:

|               | Item  | Configuration                                                                                                            |  |  |  |
|---------------|-------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Control regi  | ster  | Port mode register (PMm: $m = 0, 2 \text{ to } 6$ )<br>Pull-up resistor option register (PUm: $m = 0, 2 \text{ to } 6$ ) |  |  |  |
| Port          | Total | 47 lines                                                                                                                 |  |  |  |
|               | Input | 8 lines                                                                                                                  |  |  |  |
|               | 1/0   | 39 lines                                                                                                                 |  |  |  |
| Pull-up resis | stor  | 39 lines (software control)                                                                                              |  |  |  |

Table 4-2. Port Configuration

#### 4.2.1 Port 0

This is a 4-bit I/O port with output latch. Port 0 can be specified in the input or output mode in 1-bit units by using the port mode register 0. When P00 to P03 pins are used as input port pins, internal pull-up resistors can be connected in bit-wise by using the pull-up resistor option register 0.

The five port pins are also used to input external interrupts, a timer output stop interrupt, and an external trigger signal for the A/D converter.

Port 0 is set in the input mode when the RESET signal is input.

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

Caution Because port 0 is also used as an external interrupt input pin, an interrupt request flag is set when the port is specified in the output mode and its output level is changed. When using port 0 in the output mode, therefore, set the interrupt mask flag to 1.

## 6427525 0099517 465 🖿

Figure 4-2. Block Diagram of P00 to P03



PU : pull-up resistor option register

- PM : port mode register
- RD : read signal of port 0
- WR : write signal of port 0

## 4.2.2 Port 1

58

This is an 8-bit input port. The pins of this port are used as the analog input pins of the A/D converter. Figure 4-3 shows the block diagram of port 1.





#### 🖬 6427525 0099518 3TI 📰

#### 4.2.3 Port 2

This is an 7-bit I/O port with output latch. P20 to P26 pins can be specified in the input or output mode in 1-bit units by using the port mode register 2. When using P20 to P26 pins as input port pins, internal pull-up resistors can be connected bit-wise by using the pull-up resistor option register 2.

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

This port is set in the input mode when the RESET signal is input.

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

Caution When performing transmission using the serial interface or timer output, set the pins to be used to the output mode, and set the output latch to 0.

When performing reception or timer input, set the pins to be used to the input mode.



Figure 4-4. Block Diagram of P20 to P26

- PU : pull-up resistor option register
- PM : port mode register
- RD : read signal of port 2
- WR : write signal of port 2

#### 4.2.4 Port 3

This is an 8-bit I/O port with output latch. P30 to P37 pins can be specified in the input or output mode in 1-bit units by using the port mode register 3. When using P30 to P37 pins as input port pins, internal pull-up resistors can be connected bit-wise by using the pull-up resistor option register 3.

The pins of this port are also used as the real-time output port.

This port is set in the input mode when the RESET signal is input.

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

#### Figure 4-5. Block Diagram of P30 to P37



🖬 6427525 0099520 TST 📰

- PU : pull-up resistor option register
- PM : port mode register
- RD : read signal of port 3
- WR : write signal of port 3

## 4.2.5 Port 4

This is an 8-bit I/O port with output latch. P40 to P47 pins can be specified in the input or output mode bit-wise by using the port mode register 4. When using P40 to P47 pins as input port pins, internal pull-up resistors can be connected bit-wise by using the pull-up resistor option register 4.

These port pins are also multiplexed with an address/data bus that is used in the external memory extension mode. This port is set in the input mode when the RESET signal is input.

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





- PU : pull-up resistor option register
- PM : port mode register
- RD : read signal of port 4
- WR : write signal of port 4

🛚 6427525 0099521 996 🖿

#### 4.2.6 Port 5

This is an 8-bit I/O port with output latch. P50 to P57 pins can be specified in the input or output mode in 1-bit units by using the port mode register 5. When using P50 to P57 pins as input port pins, internal pull-up resistors can be connected bit-wise by using the pull-up resistor option register 5.

Port 5 can directly drive an LED.

These port pins are also multiplexed with an address bus that is used in the external memory extension mode.

This port is set in the input mode when the RESET signal is input.

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





- PU : pull-up resistor option register
- PM : port mode register

62

- RD : read signal of port 5
- WR : write signal of port 5

6427525 0099522 822 🔳

#### 4.2.7 Port 6

This is an 4-bit I/O port with output latch. Pins P64 to P67 can be specified in the input or output mode in 1-bit units by using the port mode register 6. When pins P64 to P67 are used as input ports, an on-chip pull-up resistor can be connected to them bit-wise with a pull-up resistor option register 6.

These port pins are also used to output control signals in the external memory extension mode.

This port is set in the input mode when the RESET signal is input.

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

## Caution P66 can be used as an I/O port pins when no external wait state is used in the external memory extension mode.



Figure 4-8. Block Diagram of P64 to P67

- PU : pull-up resistor option register
- PM : port mode register
- RD : read signal of port 6
- WR : write signal of port 6

#### I 6427525 0099523769 🎟

#### 4.3 Registers Controlling Port Functions

The following two types of registers control the ports:

- Port mode registers (PM0, PM2, PM3, PM4, PM5, PM6)
- Pull-up resistor option register (PU0, PU2, PU3, PU4, PU5, PU6)

#### (1) Port mode registers (PM0, PM2, PM3, PM4, PM5, PM6)

These registers set the corresponding ports in the input or output mode in 1-bit units. PM0, PM2, PM3, PM4, PM5, and PM6 are manipulated by a 1-bit or 8-bit memory manipulation instruction. When the RESET signal is input, these registers are set to FFH.

Caution Because port 0 is multiplexed with external interrupt input pins, interrupt request flags are set when the output mode of the port function is specified and the output level is changed. To use this port in the output mode, therefore, set 1 to the interrupt mask flags in advance.

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



## 64275250099524 6T5 🎟

(2) Pull-up resistor option register (PU0, PU2, PU3, PU4, PU5, PU6)

This register sets whether the internal pull-up resistor is connected to each port. PUm (m = 0, 2 to 6) can specify connection of a pull-up resistor to the pins of each port. PUm (m = 0, 2 to 6) is set by a 1-bit or 8-bit memory manipulation instruction. This register is set to 00H when the  $\overrightarrow{\text{RESET}}$  signal is input.

Caution Port 1 is not provided with an internal pull-up resistor.

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

| Symbol | 7    | 6        | 5    | 4        | 3     | 2    | 1    | 0    | Add  | dress   | On reset                   | R/W                   |
|--------|------|----------|------|----------|-------|------|------|------|------|---------|----------------------------|-----------------------|
| PU0    | 0    | 0        | 0    | 0        | PU03  | PU02 | PU01 | PU00 | FF   | 30H     | 00H                        | R/W                   |
|        |      | _        |      |          |       |      |      |      | -    |         |                            |                       |
| PU2    | 0    | PU26     | PU25 | PU24     | PU23  | PU22 | PU21 | PU20 | FF   | 32H     | 00Н                        | R/W                   |
|        |      |          |      |          |       |      |      |      | •    |         |                            |                       |
| PU3    | 0    | PU36     | PU35 | PU34     | PU33  | PU32 | PU31 | PU30 | FF   | 33H     | 00H                        | R/W                   |
|        |      |          |      |          |       |      |      |      | -    |         |                            |                       |
| PU4    | PU47 | PU46     | PU45 | PU44     | PU43  | PU42 | PU41 | PU40 | FF   | 34H     | 00H                        | R/W                   |
|        |      |          |      |          | ·     |      |      |      | 3    |         |                            |                       |
| PU5    | PU57 | PU56     | PU55 | PU54     | PU53  | PU52 | PU51 | PU50 | FF   | 35H     | 00H                        | R/W                   |
|        | •    |          | ·    | <u>.</u> | ··· · |      |      |      | 3    |         |                            |                       |
| PU6    | PU67 | PU66     | PU65 | PU64     | 0     | 0    | 0    | 0    | FF   | 36H     | 00Н                        | R/W                   |
|        |      | <u> </u> |      |          | r     | 1    |      |      | 3    |         |                            |                       |
|        |      |          |      |          |       |      |      |      |      |         |                            |                       |
|        |      |          |      |          | L     |      |      |      | PUmn | Selects | s internal pull-u          | p resistor of Pmn pin |
|        |      |          |      |          |       |      |      |      |      |         | n = 0 to 3)<br>n = 0 to 6) |                       |
|        |      |          |      |          |       |      |      |      |      |         | 4, 5: n = 0  to  3         | 7)                    |
|        |      |          |      |          |       |      |      |      |      |         | n = 4 to 7)                | · /                   |
|        |      |          |      |          |       |      |      |      | 0    | Interna | I pull-up resiste          | or is not used        |
|        |      |          |      |          |       |      |      |      | 1    | Interna | I pull-up resisto          | or is used            |

6427525 0099525 531 📖

#### 4.4 Operation of Port Functions

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

#### 4.4.1 Writing to I/O port

#### (1) In output mode

A value can be written to the output latch of a port by using a transfer instruction. The contents of the output latch can be output from the pins of the port.

The data once written to the output latch is retained until new data is written to the output latch.

#### (2) In input mode

A value can be written to the output latch by using a transfer instruction. However, the status of the port pin is not changed because the output buffer is OFF.

The data once written to the output latch is retained until new data is written to the output latch.

Caution A 1-bit memory manipulation instruction is executed to manipulate 1 bit of a port. However, this instruction accesses the port in 8-bit units. When this instruction is executed to manipulate a bit of an input/output port, therefore, the contents of the output latch of the pin that is set in the input mode and not subject to manipulation become undefined.

#### 4.4.2 Reading from I/O port

#### (1) In output mode

The contents of the output latch can be read by using a transfer instruction. The contents of the output latch are not changed.

#### (2) In input mode

The status of a pin can be read by using a transfer instruction. The contents of the output latch are not changed.

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

#### (1) In output mode

An arithmetic operation can be performed with the contents of the output latch. The result of the operation is written to the output latch. The contents of the output latch are output from the port pins. The data once written to the output latch is retained until new data is written to the output latch.

#### (2) In input mode

66

The contents of the output latch become undefined. However, the status of the pin is not changed because the output buffer is OFF.

Caution A 1-bit memory manipulation instruction is executed to manipulate 1 bit of a port. However, this instruction accesses the port in 8-bit units. When this instruction is executed to manipulate a bit of an input/output port, therefore, the contents of the output latch of the pin that is set in the input mode and not subject to manipulation become undefined.

📕 6427525 0099526 47A 🖿

## CHAPTER 5 CLOCK GENERATION CIRCUIT

## 5.1 Function of Clock Generation Circuit

The clock generation circuit generates the clock to be supplied to the CPU and peripheral hardware. The system oscillation circuit oscillates a frequency of 1.0 to 8.38 MHz. Oscillation can be stopped by executing the STOP instruction.

## 5.2 Configuration of Clock Generation Circuit

The clock generation circuit consists of the following hardware:

| Table 5-1. | Configuration | of Clock | <b>Generation Circuit</b> |  |
|------------|---------------|----------|---------------------------|--|
|------------|---------------|----------|---------------------------|--|

| Item                | Configuration                          |
|---------------------|----------------------------------------|
| Control register    | Processor clock control register (PCC) |
| Oscillation circuit | System clock oscillation circuit       |





## 5.3 Register Controlling Clock Generation Circuit

The clock generation circuit is controlled by the processor clock control register (PCC). This register selects the CPU clock.

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

This register is set to 04H when the RESET signal is input.





Caution Be sure to clear bit 3 to bit 7 to 0.

Remarks 1. fx : system clock oscillation frequency 2. ( ): at fx = 8.38 MHz operation

🖬 6427525 0099528 240 🖿

## 5.4 System Clock Oscillation Circuits

#### 5.4.1 System clock oscillation circuit

The main system clock oscillation circuit is oscillated by the crystal or ceramic resonator (8.38 MHz TYP.) connected across the X1 and X2 pins.

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

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

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

(a) Crystal or ceramic oscillation





(b) External clock

- Cautions 1. The STOP instruction cannot be excuted when the external clock is input because the X2 pin is pulled up to Voo1.
  - 2. When using the subsystem clock oscillation circuit, to avoid influence of wiring capacity, etc. wire the portion enclosed by dotted line in Figure 5-3 as follows:
    - Keep the wiring length as short as possible.
    - Do not cross the wiring with any other signal lines. Do not route the wiring in the vicinity
      of a line through which a high alternating current flows.
    - Always keep the ground of the capacitor of the oscillation circuit at the same potential as Vss1. Do not ground the capacitor to a ground pattern through which a high current flows.
    - Do not extract a signal from the oscillation circuit.

Figure 5-4 shows incorrect examples of resonator connection.

64275250099529 187 📟

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

(a) Too long wiring

(b) Crossed signal line





(c) Wiring near high alternating current



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





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

(e) Signal are fetched



## 5.4.2 Divider circuit

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

## 6427525 0099531 835 🖿

-----

#### 5.5 Operation of Clock Generation Circuit

The clock generation circuit generates the following clocks and control the operation modes of the CPU, such as the standby mode:

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

The operation of the clock generation circuit is determined by the processor clock control register (PCC), as follows:

- (a) The slowest mode (3.8 μs: at 8.38-MHz operation) of the system clock is selected when the RESET signal is generated (PCC = 04H). While a low level is input to the RESET pin, oscillation of the system clock is stopped.
- (b) Five types of CPU clocks (0.24  $\mu$ s, 0.48  $\mu$ s, 0.96  $\mu$ s, 1.9  $\mu$ s, and 3.8  $\mu$ s: at 8.38-MHz operation) can be selected by the PCC setting with the system clock selected.
- (c) Two standby modes, STOP and HALT, can be used.
- (d) The clock to the peripheral hardware is supplied by dividing the system clock. Therefore, the other peripheral hardware is stopped when the system clock is stopped (except, however, the external clock input operation).

## 5.6 Changing Setting of CPU Clock

#### 5.6.1 Time required for switching CPU clock

The CPU clock can be selected by using bits 0 to 2 (PCC0 to PCC2) of the processor clock control register (PCC). Actually, the specified clock is not selected immediately after the setting of PCC has been changed, and the old clock is used for the duration of several instructions after that (refer to **Table 5-2**).

| Set Value before<br>Switching |      | Set Value after Switching |                |      |                 |                |      |                 |      |               |                 |                |      |                 |      |      |      |      |
|-------------------------------|------|---------------------------|----------------|------|-----------------|----------------|------|-----------------|------|---------------|-----------------|----------------|------|-----------------|------|------|------|------|
| PCC2                          | PCC1 |                           | PCC1 PCC0      | PCC2 | PCC1            | PCCO           | PCC2 | PCC1            | PCCO | PCC2          | PCC1            | PCCO           | PCC2 | PCC1            | PCC0 | PCC2 | PCC1 | PCC0 |
| 1002                          | 7001 | 1000                      | 0              | 0    | 0               | 0              | 0    | 1               | 0    | 1             | 0               | 0              | 1    | 1               | 1    | 0    | 0    |      |
| 0                             | 0    | o                         |                |      | 16 instructions |                |      | 16 instructions |      |               | 16 instructions |                |      | 16 instructions |      |      |      |      |
| 0                             | 0    | 1                         | 8 instructions |      | ions            |                |      | 8 instructions  |      |               | 8 instructions  |                |      | 8 instructions  |      |      |      |      |
| 0                             | 1    | o                         | 4 instructions |      | ions            | 4 instructions |      |                 |      |               | 4 instructions  |                | ions | 4 instructions  |      |      |      |      |
| 0                             | 1    | 1                         | 2 instructions |      | ons             | 2 instructions |      | 2 instructions  |      |               |                 | 2 instructions |      |                 |      |      |      |      |
| 1                             | 0    | o                         | 1 instruction  |      | ion             | 1 instruction  |      | 1 instruction   |      | 1 instruction |                 |                |      |                 |      |      |      |      |

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

Remark One instruction is the minimum instruction execution time of the CPU clock before switching.

## 🖬 6427525 0099533 608 🛲

#### 5.6.2 Switching CPU clock

The following figure illustrates how the CPU clock is switched.



Figure 5-5. Switching between System Clock and CPU Clock

- <1> The CPU is reset when the RESET pin is made low on power application. The effect of resetting is released when the RESET pin is later made high, and the system clock starts oscillating. At this time, the time during which oscillation stabilizes (2<sup>17</sup>/fx) is automatically secured. After that, the CPU starts instruction execution at the slowest speed of the system clock (3.8 μs: at 8.38-MHz operation).
- <2> After the time during which the VDD1 voltage rises to the level at which the CPU can operate at the highest speed has elapsed, processor clock control register (PCC) is rewritten so that the highest speed can be selected.

6427525 0099534 544 📖

#### 6.1 Real-Time Output Port Functions

Data set previously in the real-time output buffer register can be transferred to the output latch by hardware concurrently with timer interrupts or external interrupt generation, then output externally. This is called the real-time output function. The pins that output data externally are called real-time output ports.

By using a real-time output, a signal which has no jitter can be output. This port is therefore suitable for control of stepping motors, etc.

Port mode/real-time output port mode can be specified bit-wise.

.

🔲 6427525 0099535 480 📟

## 6.2 Real-Time Output Port Configuration

The real-time output port consists of the following hardware.

| item             | Configuration                                   |
|------------------|-------------------------------------------------|
| Register         | Real-time output buffer register (RTBL0, RTBH0) |
| Control register | Real-time output port mode register (RTPM0)     |
|                  | Real-time output port control register (RTPC0)  |

Table 6-1. Real-Time Output Port Configuration







Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### (1) Real-time output buffer register (RTBL0, RTBH0)

These are 4-bit registers that hold output data in advance.

Addresses of RTBL0 and RTBH0 are mapped individually in the Special function register (SFR) area as shown in Figure 6-2.

When specifying 4 bits × 2 channels as the operating mode, data are set individually in RTBL0 and RTBH0. The data of both RTBL0 and RTBH0 can be read all at once regardless of which address is specified.

When specifying 8 bits  $\times$  1 channel as the operating mode, data are set to both RTBL0 and RTBH0 by writing 8-bit data to either RTBL0 or RTBH0. The data of both RTBL0 and RTBH0 can be read all at once regardless of which address is specified.

Table 6-2 shows operations during manipulation of RTBL0 and RTBH0.





## Table 6-2. Operation in Real-Time Output Buffer Register Manipulation

| Operating Mode      | Register to be | In Rea        | d Note1      | In Write Note2 |              |
|---------------------|----------------|---------------|--------------|----------------|--------------|
|                     | Manipulated    | Higher 4 Bits | Lower 4 Bits | Higher 4 Bits  | Lower 4 Bits |
| 4 Bits × 2 Channels | RTBLO          | RTBHO         | RTBL0        | Invalid        | RTBL0        |
|                     | RTBHO          | RTBHO         | RTBLO        | RTBH0          | Invalid      |
| 8 Bits x 1 Channel  | RTBLO          | RTBHO         | RTBL0        | RTBHO          | RTBL0        |
|                     | RTBHO          | RTBHO         | RTBL0        | RTBH0          | RTBLO        |

Notes 1. Only the bits set in the real-time output port mode can be read. When a bit set in the port mode is read, 0 is read.

2. After setting data in the real-time output port, output data should be set in RTBL0 and RTBH0 by the time a real-time output trigger is generated.

#### 6427525 0099537 253 📖

## 6.3 Registers Controlling Real-Time Output Port

The following two types of registers control the real-time output ports.

- Real-time output port mode register (RTPM0)
- · Real-time output port control register (RTPC0)

#### (1) Real-time output port mode register (RTPM0)

This register sets the real-time output port mode or port mode in 1-bit units. RTPM0 is manipulated by a 1-bit or 8-bit memory manipulation instruction. When the RESET signal is input, this register is set to 00H.

#### Figure 6-3. Format of Real-Time Output Port Mode Register

| Symbol | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      | Address | On reset | R/W |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|---------|----------|-----|
| RTPM0  | RTPM07 | RTPM06 | ATPM05 | rtpm04 | RTPM03 | RTPM02 | RTPM01 | RTPM00 | FF86H   | 00H      | R/W |
|        |        |        |        |        |        |        |        |        |         |          |     |

| RTPM0m | Real-Time Output Port Selection (m = 0 to 7) |
|--------|----------------------------------------------|
| 0      | Port mode                                    |
| 1      | Real-time output port mode                   |

- Cautions 1. When using a real-time output port, set the port to be used as a real-time output port in the output mode.
  - 2. The port specified as a real-time output port cannot set data to its output latch. To set an initial value, therefore, set data to the output latch before setting the real-time output port mode.

#### 🔳 6427525 0099538 19T 💻

## (2) Real-time output port control register (RTPC0)

This register sets an operating mode of real-time output port and output trigger.

The relation between the operating mode of the real-time output port and output trigger is as shown in Table 6-3.

RTPC0 is manipulated by a 1-bit or 8-bit memory manipulation instruction.

When the RESET signal is input, this register is set to 00H.

## Figure 6-4. Format of Real-Time Output Port Control Register

| Symbol | 7      | 6      | 5     | 4     | 3 | 2 | 1 | 0 | Address | On reset | R/W |
|--------|--------|--------|-------|-------|---|---|---|---|---------|----------|-----|
| RTPC0  | RTPOE0 | RTPEG0 | BYTE0 | EXTR0 | 0 | 0 | 0 | 0 | FF87H   | 00H      | R/W |

| RTPOE0 | Controls operation of real-time output port. |
|--------|----------------------------------------------|
| 0      | Disables operation <sup>Note</sup> .         |
| 1      | Enables operation.                           |

| RTPEG0 | Specifies valid edge of INTP2. |
|--------|--------------------------------|
| 0      | Falling edge                   |
| 1      | Rising edge                    |

| BYTE0 | Operating mode of real-time output port |
|-------|-----------------------------------------|
| 0     | 4 bits x 2 channels                     |
| 1     | 8 bits x 1 channel                      |

| EXTR0 | Controls real-time output by INTP2.             |
|-------|-------------------------------------------------|
| 0     | Does not use INTP2 as real-time output trigger. |
| 1     | Uses INTP2 as real-time output trigger.         |

Note When the real-time output operation is disabled (RTPOE0 = 0), RTP0 to RTP7 output "0".

## Table 6-3. Real-Time Output Port Operating Mode and Output Trigger

| BYTE0 | EXTR0 | Operating Mode      | RTBH0 → Port Output | RTBL0 → Port Output |
|-------|-------|---------------------|---------------------|---------------------|
| 0     | 0     | 4 bits x 2 channels | INTTM52             | INTTM50             |
| 0     | 1     |                     | INTTM50             | INTP2               |
| 1     | 0     | 8 bits x 1 channel  | INTTM50             | I                   |
| 1     | 1     |                     | INTP2               | ·                   |

#### 🛚 6427525 0099539 026 🎟

## 6.4 Operation of Real-Time Output Port

If the real-time output operation is enabled by setting bit 7 (RTPOE0) of the real-time output port control register (RTPC0) to 1, the data of the real-time output buffer registers (RTBH0 and RTBL0) are transferred to the output latch in synchronization with the generation of a transfer trigger (which is selected by EXTR0 and BYTE0<sup>Note</sup>). Of the transferred data, only the data of the bits specified as the real-time output port by the real-time output port mode register (RTPM0) are output from bits RTP0 to RTP7. The port pin set by RTPM0 in the port mode can be used as a general-purpose I/O port pin.

If the real-time output operation is disabled by RTPOE0 = 0, RTP0 to RTP7 output 0 regardless of the setting of RTPM0.

Note EXTR0: Bit 4 of real-time output port control register (RTPC0) BYTE0: Bit 5 of real-time output port control register (RTPC0)





6427525 0099540 848 📟

A: Software processing by INTTM52 (RTBH0 write)

B: Software processing by INTTM50 (RTBL0 write)

Powered by ICminer.com Electronic-Library Service CopyRight 2003

## 6.5 Using Real-Time Output Port

When using the real-time output port, perform the setting in the following procedure.

(1) Disable real-time output operation.

Clear bit 7 (RTPOE0) of the real-time output port control register (RTPC0) to 0.

- (2) initial setting
  - Set the initial value to the output latch.
  - Specify the real-time output port mode or port mode bitwise. Set the real-time output port mode register (RTPM0).
  - Select a trigger and a valid edge. Set bits 4, 5, and 6 (EXTR0, BYTE0, and RTPEG0) of RTPC0.
  - Set the same initial value as the output latch to the real-time output buffer registers (RTBH0 and RTBL0).
- (3) Enable the real-time output operation. RTPOE0 = 1
- (4) Set the next output to RTBH0 and RTBL0 until the selected transfer trigger is generated.
- (5) Sequentially set the next real-time output value to RTBH0 and RTBL0 by using the interrupt processing corresponding to the selected trigger.
- 6.6 Notes on Real-Time Output Port
  - (1) Before performing the initial setting, disable the real-time output operation by clearing bit 7 (RTPOE0) of the real-time output port control register (RTPC0) to 0.
  - (2) Once the real-time output operation has been disabled (RTPOE0 = 0), be sure to set the same initial value as the output latch to the real-time output buffer registers (RTBH0 and RTBL0) before enabling the real-time output operation (RTPOE0 = 0 -> 1).

[MEMO]

# PAGE(S) INTENTIONALLY BLANK

82

Powered by ICminer.com Electronic-Library Service CopyRight 2003

🖬 6427525 0099542 630 페

## CHAPTER 7 10-BIT INVERTER CONTROL TIMER

## 7.1 Functions of 10-Bit Inverter Control Timer

The 10-bit inverter control timer (TM7) realizes inverter control. It incorporates an 8-bit timer for dead time generation and can output waveforms that don't overlap active levels. A total of six positive phase and negative phase channels are output. In addition, an active level change function and output stop function by external interrupt or watchdog timer interrupt are provided.

## 7.2 Configuration of 10-Bit Inverter Control Timer

The 10-bit inverter control timer (TM7) consists of the following hardware.

| Item             | Function                                                                                                                                           |          |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| Timer counter    | 10-bit up/down counter (TM7) x 1<br>8-bit down counters (DTM6, DTM1, DTM2) x 3<br>3-bit down counter (RTM0) x 1                                    |          |
| Register         | 10-bit compare registers (CM0, CM1, CM2, CM3) x 4<br>10-bit buffer registers (BFCM0, BFCM1, BFCM2, BFCM3) x 4<br>8-bit reload register (DTIME) x 1 |          |
| Timer output     | 6 (T070, T071, T072, T073, T074, T075)                                                                                                             | <u> </u> |
| Control register | Inverter timer control register 7 (TMC7)<br>Inverter timer mode register 7 (TMM7)                                                                  | <u></u>  |

## Table 7-1. Configuration of 10-Bit Inverter Control Timer

🖿 6427525 0099543 557 🎞

-----

----





Powered by ICminer.com Electronic-Library Service CopyRight 2003

64275250099544493 🎟

# (1) 10-bit inverter control timer (TM7)

TM7 is a 10-bit up/down counter that counts count pulses in synchronization with the rising edge of the count clock. When the timer starts, the number of count pulse count is incremented from 0, while when the value of the preset compare register 3 (CM3) and the TM7 counting match, it is switched to the count down operation.

An underflow signal is generated if the value becomes 000H during the count down operation and an interrupt request signal INTTM7 is generated. When underflow occurs, it is switched from the count down operation to the count up operation. INTTM7 is normally generated at every underflow but the number of occurrences can be divided by the IDEV0 to IDEV2 bits of inverter timer control register 7 (TMC7). TM7 cannot be read/written.

The cycle of TM7 is controlled by CM3.

The count clock can be selected among 6 types: fx, fx/2, fx/4, fx/8, fx/16, fx/32. RESET input or clearing the CE7 bit of the TMC7 register sets TM7 to 000H.

# (2) 10-bit compare registers 0 to 2 (CM0 to CM2)

CM0 to CM2 are 10-bit compare registers that always compare their own value with that of TM7, and if they coincide the contents of the flip-flops are changed.

Each of CM0 to CM2 are provided with a buffer register (BFCM0 to BFCM2), so that the contents of the buffer can be transferred to CM0 to CM2 with the timing of interrupt request signal INTTM7 generation. Write operation to CM0 to CM2 is possible only during TM7 stop.

To set the output timing, perform data write to BFCM0 to BFCM3.

RESET input or clearing the CE7 bit of the TMC7 register sets these registers to 000H.

# (3) 10-bit compare register 3 (CM3)

CM3 is a 10-bit compare register that controls the high limit value of TM7. If the count value of TM7 coincides with the value CM3 or 0, count up/down is switched at the next count clock.

CM3 provides a buffer register (BFCM3) whose contents are transferred to CM3 with the timing of interrupt request signal INTTM7 generation.

CM3 can be written to only during TM7 stop.

To set the cycle to TM7, write data to BFCM3.

RESET input sets CM3 to 0FFH.

Do not set CM3 to 000H.

# (4) 10-bit buffer registers 0 to 3 (BFCM0 to BFCM3)

BFCM0 to BFCM3 are 10-bit registers. They transfer data to the compare register (CM0 to CM3) corresponding to each buffer with the timing of the interrupt request signal INTTM7 generation. BFCM0 to BFCM3 can be read/written irrespective of TM7 count stop or operation.

RESET input sets BFCM0 to BFCM2 and BFCM3, to 000H and 0FFH, respectively.

These registers can be read/written in word and byte units. For read/write operations of less than 8 bits, BFCM0L to BFCM3L are used.

6427525009954532T 🖿

## (5) Dead time reload register (DTIME)

DTIME is an 8-bit register to set dead time and is common to three dead time timers (DTM0 to DTM2). However, the data load timing from DTIME to DTM0, DTM1 and DTM2 is independent.

DTIME can be written only during TM7 count stop. Data does not change even if an instruction to rewrite DTIME is executed during timer operation.

RESET input sets DTIME to FFH.

Even if 00H is set to DTIME, an output with dead time fx is performed.

# (6) Dead time timers 0 to 2 (DTM0 to DTM2)

DTM0 to DTM2 are 8-bit down counters that generate dead time.

Count down is performed after the value of the dead time reload register (DTIME) is reloaded with the timing of compare match between CM0 to CM2 and TM7. DTM0 to DTM2 generate an underflow signal when 00H changes to FFH and stop with FFH.

The count clock is fx.

DTM0 to DTM2 cannot be read/written.

RESET input or clearing the CE7 bit of the TMC7 register sets these registers to FFH.

## (7) Buffer transfer control timer (RTM0)

RTM0 is a 3-bit up counter. It has the function to divide interrupt request signal INTTM7.

The number of division that is set with bits IDEV2 to IDEV0 of the TCM7 register is loaded at TM7 count start and at the generation timing of INTTM7. Incrementing is performed with the TM7 underflow signal and INTTM7 is generated when the value matches with the loaded value.

RTM0 cannot be read/written.

RESET input sets RTM0 to 7H. The division number that is set with bits IDEV2 to IDEV0 is set by generating INTTM7 and clearing the CE7 bit of the TMC7 register.

86

# 🖿 6427525 0099546 266 📟

Powered by ICminer.com Electronic-Library Service CopyRight 2003

# 7.3 Registers Controlling 10-bit Inverter Control Timer

The following two types of registers are available to control the 10-bit inverter control timer.

- Inverter timer control register 7 (TMC7)
- Inveter timer mode register 7 (TMM7)
- Inverter timer control register 7 (TMC7)
   TMC7 controls the operation of TM7, DTM0 to DTM2, and RTM0, specifies the count clock of TM7, and selects the compare register transfer cycle.
   TMC7 is set by a 1-bit or 8-bit memory manipulation instruction.
   RESET input sets TMC7 to 00H.



# Figure 7-2. Inverter Timer Control Register 7 Format

| Symbol | 7   | 6 | 5     | 4     | 3     | 2     | 1     | 0     | Address | On reset | R/W |
|--------|-----|---|-------|-------|-------|-------|-------|-------|---------|----------|-----|
| TMC7   | CE7 | 0 | TCL72 | TCL71 | TCL70 | IDEV2 | IDEV1 | IDEV0 | FF90H   | 00H      | R/W |

| CE7 | TM7, DTM0 to DTM2, RTM0 operation control |
|-----|-------------------------------------------|
| 0   | Clear and stop (TO70 to TO75 are Hi-z)    |
| 1   | Count enable                              |

| TCL72 | TCL71                | TCL70 | Count clock selection       |  |  |  |  |
|-------|----------------------|-------|-----------------------------|--|--|--|--|
| 0     | 0                    | 0     | fx (8.38 MHz)               |  |  |  |  |
| 0     | 0                    | 1     | fx/2 (4.19 MHz)             |  |  |  |  |
| 0     | 1                    | 0     | fx/2² (2.1 MHz)             |  |  |  |  |
| 0     | 1                    | 1     | fx/2³ (1.05 MHz)            |  |  |  |  |
| 1     | 0                    | 0     | fx/2* (524 kHz)             |  |  |  |  |
| 1     | 0                    | 1     | fx/2 <sup>s</sup> (262 kHz) |  |  |  |  |
| Other | Other than the above |       | Setting prohibited          |  |  |  |  |

| IDEV2 | IDEV1 | IDEV0 | INTTM7 occurrence frequency selection   |
|-------|-------|-------|-----------------------------------------|
| 0     | 0     | 0     | Occurs once every TM7 underflow.        |
| 0     | 0     | 1     | Occurs once every two TM7 underflows.   |
| 0     | 1     | 0     | Occurs once every three TM7 underflows. |
| 0     | 1     | 1     | Occurs once every four TM7 underflows.  |
| 1     | 0     | 0     | Occurs once every five TM7 underflows.  |
| 1     | 0     | 1     | Occurs once every six TM7 underflows.   |
| 1     | 1     | 0     | Occurs once every seven TM7 underflows. |
| 1     | 1     | 1     | Occurs once every eight TM7 underflows. |

**Remark** Figures in parentheses apply to operation with fx = 8.38 MHz.

88

🖬 6427525 0099548 039 🖿

## (2) Inverter timer mode register 7 (TMM7)

TMM7 controls the operation of and specifies active level of TO70 to TO75 outputs, and sets the valid edge of TOFF7.

TMM7 is set by a 1-bit or 8-bit memory manipulation instruction. RESET input sets TMM7 to 00H.

Figure 7-3. Inverter Timer Mode Register 7 Format

#### 7 Symbol 6 5 4 3 2 1 0 Address On reset R/W TMM7 0 0 0 PNOFFB ALV TOEDG TOSPPTOSPW FF91H 00H R/W

| PNO | FFB. | Control status flag of TM7 output to TO70 to TO75 |
|-----|------|---------------------------------------------------|
| 0   |      | TM7 output disable status (TO70 to TO75 are Hi-z) |
| 1   |      | TM7 output enable status                          |

| ALV | TO70 to TO75 output active level specification |
|-----|------------------------------------------------|
| 0   | Low level                                      |
| 1   | High level                                     |

| TOEDG | TOFF7 valid edge specification |
|-------|--------------------------------|
| 0     | Falling edge                   |
| 1     | Rising edge                    |

| TOSPP | TO70 to TO75 output stop control by valid edge |
|-------|------------------------------------------------|
| 0     | Does not stop output                           |
| 1     | Stops output (TO70 to TO75 are Hi-z)           |

| TOSPW | TO70 to TO75 output stop control by INTWDT |
|-------|--------------------------------------------|
| 0     | Does not stop output                       |
| 1     | Stops output (TO70 to TO75 are Hi-z)       |

Note The PNOFFB bit is a read-only flag. This bit cannot be set or reset by software. PNOFFB is reset when an output stop is caused by TOFF7 and INTWDT during TM7 stop (CE7 = 0) or operation (CE7 = 1).

Caution Always set bits 5 to 7 of TMM7 to 0.

**Remarks** 1. TO70 to TO75 become Hi-z state in the following cases. However, the TM7, DTM0 to DTM2, and RTM0 timers do not stop if CE7 = 1 is set.

• A valid edge is input to the TOFF7 pin while TOSPP = 1.

• A specified interrupt is generated while TOSPW = 1.

To restore the output of TO70 to TO75, perform the procedure below.

<1> Write 0 to CE7 and stop the timer.

<2> Write 0 to the output stop function flag that is used.

<3> Reset the registers to their default values.

2. PNOFFB, ALV, CE7, and TO70 to TO75 are related as follows.

| PNOFFB | ALV | ÇE7 | T070, T072, T074 | T071, T073, T075 |
|--------|-----|-----|------------------|------------------|
| 0      | 0   | 0   | Hi-z             | Hi-z             |
| 0      | 1   | 0   | Hi-z             | Hi-z             |
| 0      | 0/1 | 1   | Hi-z             | Hi-z             |
| 1      | 0/1 | 1   | PWM wave output  | PWM wave output  |

# 7.4 Operation of 10-Bit Inverter Control Timer

### (1) Setting procedure

- (a) The TM7 count clock is set with the TCL70 to TCL72 bits of inverter timer control register 7 (TMC7) and the occurrence frequency of INTTM7 is set with the IDEV0 to IDEV2 bits.
- (b) The active level of the TO70 to TO75 pins is set with the ALV bit of inverter timer mode register 7 (TMM7).
- (c) Set the half width of the first PWM cycle to CM3.
  PWM cycle = CM3 value × 2 × TM7 clock rate (The clock rate of TM7 is set with the TMC7 register)
- (d) Set the half width of the second PWM cycle to BFCM3.
- (e) Set the dead time width to DTIME.
  Dead time width = (DTIME + 1) × fx fx: internal system clock
- (f) Set F/F set/reset timing that is used during the first cycle to CM0 to CM2.
- (g) Set F/F set/reset timing that is used during the second cycle to BFCM3.
- (h) After the CE7 bit of the TMC7 register is set (1), the operation of TM7, DTM0 to DTM2, and RTM0 is enabled.

Caution Always use a bit manipulation instruction to set the CE7 bit.

- (i) Set the F/F set/reset timing that is used for the next cycle to BFCM0 to BFCM3 during TM7 operation.
- (j) To stop the TM7 operation, set the CE7 bit of the TMC7 register to 0.

Caution Another bit cannot be rewritten at the same time that the CE7 bit is being rewritten.

6427525 0099551 623 🔳

# (2) Output waveform widths corresponding to set values

- PWM cycle = CM3 × 2 × TTM7
- Dead time width =  $ToTM = (DTIME + 1) \times fx$
- Active width of positive phase (TO70, TO72, TO74 pin)
- $= \{(CM3 CM_{up}) + (CM3 CM_{down})\} \times TTM7 TDTM$
- Active width of negative phase (TO71, TO73, TO75 pin)
  - =  $(CM_{down} + CM_{up}) \times TTM7 TDTM$
- fx : System clock oscillation frequency

Tтм7 : TM7 count clock

CMup : Set value of CM0 to CM2 during TM7 count up

CMdown : Set value of CM0 to CM2 during TM7 count down

Caution If a value whose active width in the positive phase or negative phase becomes 0 or negative via the above calculation, TO70 to TO75 output a waveform fixed at inactive level during active width 0.

# (3) Operation timing



Figure 7-4. TM7 Operation Timing (Basic Operation)

**Remarks** 1. n = 0 to 2

2. t: Dead time = (DTIME + 1)  $\times$  fx

(fx: System clock oscillation frequency)

3. The above figure assumes an active high and undivided INTTM7 occurrence.

🔳 6427525 0099553 4T6 🎟

93

\_\_\_\_\_





Remarks 1. n = 0 to 2

94

2. t: Dead time = (DTIME + 1)  $\times$  fx

(fx: System clock oscillation frequency)

3. The above figure assumes an active high and undivided INTTM7 occurrence.

If a value higher than CM3 is set to BFCMn, high-level output in the positive phases (TO70, TO72, TO74 pins), and low-level output in the negative phases (TO71, TO73, TO75 pins) are continued. This setting is effective to output signals whose low and high widths are longer than the PWM cycle when controlling the inverter, etc.

🖬 6427525 0099554 332 **m** 

Figure 7-6. TM7 Operation Timing (CMn (BFCMn) = 000H)



**Remarks** 1. n = 0 to 2

2. t: Dead time = (DTIME + 1)  $\times$  fx

(fx: System clock oscillation frequency)

3. The above figure assumes an active high and undivided INTTM7 occurrence.







Remarks 1. n = 0 to 2

96

2. The above figure assumes an active high and undivided INTTM7 occurrence.

🖬 6427525 0099556 los 페

Powered by ICminer.com Electronic-Library Service CopyRight 2003

# CHAPTER 8 8-BIT TIMER/EVENT COUNTER

## 8.1 Function of 8-Bit Timer/Event Counter

The 8-bit timer/event counters (TM50, TM51, and TM52) have the following two modes:

- Mode in which an 8-bit timer/event counter is used alone (single mode)
- Mode in which two or more 8-bit timer/event counters are connected in cascade (16-bit resolution: cascade mode)

These two modes are explained below.

- (1) Mode in which an 8-bit timer/event counter is used alone (single mode) In this mode, the following functions can be used.
  - Interval timer
  - External event counter
  - Square wave output
  - PWM output
- (2) Mode in which TM50 and TM51, or TM51 and TM52 are connected in cascade (16-bit resolution: cascade mode)

By connecting 8-bit timer/event counters in cascade, they can be used as a 16-bit timer/event counter. In the cascade mode, the following functions can be used.

- 16-bit resolution interval timer
- 16-bit resolution external event counter
- 16-bit resolution square wave output

Figures 8-1 to 8-3 show the block diagrams of 8-bit timer/event counters.

# 🔲 6427525 0099557 041 🖿

......

# 8.2 Configuration of 8-Bit Timer/Event Counter

An 8-bit timer/event counter consists of the following hardware:

| ltem             | Configuration                                                                          |  |  |  |  |  |
|------------------|----------------------------------------------------------------------------------------|--|--|--|--|--|
| Timer register   | 8-bit counter 5n (TM5n)                                                                |  |  |  |  |  |
| Register         | 8-bit compare register 5n (CR5n)                                                       |  |  |  |  |  |
| Timer output     | TO5n                                                                                   |  |  |  |  |  |
| Control register | 8-bit timer mode control register 5n (TMC5n)<br>Timer clock select register 5n (TCL5n) |  |  |  |  |  |

Table 8-1. Configuration of 8-Bit Timer/Event Counter

Remark n = 0 to 2



🖬 6427525 0099558 T88 🖬









🛚 6427525 0099559 914 🎞

Powered by ICminer.com Electronic-Library Service CopyRight 2003



Figure 8-3. 8-Bit Timer/Event Counter 52 (TM52) Block Diagram



🖬 6427525 0099560 636 📰

#### (1) 8-bit timer counters 50, 51, and 52 (TM50, TM51, and TM52)

TM50, TM51, and TM52 are 8-bit read-only registers that count count pulses.

These counters are incremented in synchronization with the rising edge of the count clock.

TM50 and TM51, or TM51 and TM52 can be connected in cascade and can be used as a 16-bit timer.

When TM50 and TM51 are connected in cascade and used as a 16-bit timer, the values of these timers/ counters can be read by using a 16-bit manipulation instruction. TM50 and TM51 are connected with an internal 8-bit bus, and TM50 and TM51 are read one at a time. This means that the value of, say, TM50 may change while that of TM51 is read. Therefore, read TM50 and TM51 two times to compare their first and second values for the sake of accuracy.

When TM51 and TM52 are connected in cascade and used as a 16-bit timer, they cannot be read by using a 16-bit manipulation instruction. When reading the TM51 and TM52, read the TM51 and TM52 separately by using an 8-bit manipulation instruction.

If the count value is read during operation, input of the count clock is temporarily stopped, and the count value at that point is read. The count value is cleared to 00H in the following cases:

- <1> RESET input
- <2> Clearing TCE5n

<3> Coincidence between TM5n and CR5n in clear & start mode

Caution In the cascade mode, the 16-bit timer is cleared to 00H regardless of whether TCE51 of TM51 or TCE52 of TM52 is cleared.

Remark n = 0 to 2

## (2) 8-bit compare registers 50, 51, and 52 (CR50, CR51, and CR52)

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

The value of CR5n can be set in a range of 00H to FFH and can be rewritten during counting.

If TM50 and TM51 are connected in cascade and used as a 16-bit timer, CR50 and CR51 operate as a 16bit compare register. Therefore, the count value and register value are compared in 16-bit units, and if the two values coincide with each other, an interrupt request (INTTM50) is generated. At this time, INTTM51 interrupt request is also generated. When connecting TM50 and TM51 in cascade, therefore, mask the INTTM51 interrupt request.

The same applies when TM51 and TM52 are connected in cascade. If the value of the 16-bit timer coincides with that of the 16-bit compare register, the INTTM51 interrupt request is generated (mask the INTTM52 interrupt request).

Caution When setting data to the timers connected in cascade, be sure to stop the timer operation.

Remark n = 0 to 2



### 8.3 Registers Controlling 8-Bit Timer/Event Counters

The following six registers control 8-bit timer/event counters 50, 51, and 52.

- 8-bit timer mode control registers 50, 51, and 52 (TMC50, TMC51, and TMC52)
- Timer clock select registers 50, 51, and 52 (TCL50, TCL51, and TCL52)
- (1) 8-bit timer mode control registers 50, 51, and 52 (TMC50, TMC51, and TMC52) TMC50, TMC51, and TMC52 perform the following six operations:
  - <1> Control of count operation of 8-bit timer counters 50, 51, and 52 (TM50, TM51, and TM52)
  - <2> Selection of operation mode of 8-bit timer counters 50, 51, and 52 (TM50, TM51, and TM52)
  - <3> Selection of single mode or cascade mode
  - <4> Setting of status of timer output F/F (flip-flop)
  - <5> Control of timer F/F or selection of active level in PWM (free running) mode
  - <6> Control of timer output

TMC50, TMC51, and TMC52 are set by using a 1-bit or 8-bit memory manipulation instruction. The values of these registers are set to 04H at RESET.

Figures 8-4 to 8-6 show the formats of TMC50, TMC51, and TMC52.

# Figure 8-4. Format of 8-Bit Timer Mode Control Register 50

| Symbol | $\overline{\mathcal{O}}$ | 6      | 5 | 4 | 3     | 2     | 1      | 0     | <b>A d d - - - -</b> | 0        |
|--------|--------------------------|--------|---|---|-------|-------|--------|-------|----------------------|----------|
| TMC50  | TCE50                    | TMC506 | 0 | 0 | LVS50 | LVR50 | TMC501 | TOE50 |                      | On reset |
|        |                          |        |   |   |       |       |        |       | FF68H                | 04H      |

| TCE50 | Controls count operation of TM50.                                          |
|-------|----------------------------------------------------------------------------|
| 0     | Disables count operation after clearing counter to 0 (disables prescaler). |
| 1     | Starts counting.                                                           |

| TMC506 | Selects operating mode of TM50.                         |
|--------|---------------------------------------------------------|
| 0      | Clears and starts on coincidence between TM50 and CR50. |
| 1      | PWM (free running) mode                                 |

| LVS50 | LVR50 | VR50 Sets status of timer output F/F. |  |
|-------|-------|---------------------------------------|--|
| 0     | 0     | Not affected                          |  |
| 0     | 1     | Resets timer output F/F (to 0).       |  |
| 1     | 0     | Sets timer output F/F (to 1).         |  |
| 1     | 1     | Setting prohibited                    |  |

| TMC501 | Other than PWM<br>mode (TMC506 = 0) | PWM mode<br>(TMC506 = 1) |  |
|--------|-------------------------------------|--------------------------|--|
|        | Controls timer F/F.                 | Selects active level.    |  |
| 0      | Disables inverted operation.        | High active              |  |
| 1      | Enables inverted operation.         | Low active               |  |

| TOE50 | Controls timer output.       |
|-------|------------------------------|
| 0     | Disables output (port mode). |
| 1     | Enables output.              |

- **Remarks** 1. The PWM output is at the inactive level in the PWM mode because TCE50 = 0.
  - 2. If LVS50 and LVR50 are read immediately after data has been set, these bits are 0.

R/W

R/W

\_\_\_\_

\_\_\_\_

# Figure 8-5. Format of 8-Bit Timer Mode Control Register 51

On reset

04H

R/W

R/W

| Symbol | $\overline{\mathcal{O}}$ | 6      | 5 | 4      | 3     | 2     | 1      | <u> </u> | Address |
|--------|--------------------------|--------|---|--------|-------|-------|--------|----------|---------|
| TMC51  | TCE51                    | TMC516 | 0 | TMC514 | LVS51 | LVR51 | TMC511 | TOE51    | FF70H   |

| TCE51 | Controls count operation of TM51.                                          |
|-------|----------------------------------------------------------------------------|
| 0     | Disables count operation after clearing counter to 0 (disables prescaler). |
| 1     | Starts counting.                                                           |

| TMC516 | Selects operating mode of TM51.                         |
|--------|---------------------------------------------------------|
| 0      | Clears and starts on coincidence between TM51 and CR51. |
| 1      | PWM (free running) mode                                 |

| TMC514 | Selects single mode or cascade mode. |  |  |
|--------|--------------------------------------|--|--|
| 0      | Single mode                          |  |  |
| 1      | Cascade mode (connected to TM50)     |  |  |

| LVS51 | LVR51 | Sets status of timer output F/F. |
|-------|-------|----------------------------------|
| 0     | 0     | Not affected                     |
| 0     | 1     | Resets timer output F/F (to 0).  |
| 1     | 0     | Sets timer output F/F (to 1).    |
| 1     | 1     | Setting prohibited               |

| TMC511 | Other than PWM<br>mode (TMC516 = 0) | PWM mode<br>(TMC516 = 1) |  |
|--------|-------------------------------------|--------------------------|--|
|        | Controls timer F/F.                 | Selects active level.    |  |
| 0      | Disables inverted operation.        | High active              |  |
| 1      | Enables inverted operation.         | Low active               |  |

| TOE51 | Controls timer output.       |
|-------|------------------------------|
| 0     | Disables output (port mode). |
| 1     | Enables output.              |

**Remarks 1.** The PWM output is at the inactive level in the PWM mode because TCE51 = 0.

2. If LVS51 and LVR51 are read immediately after data has been set, these bits are 0.

104

🖬 6427525 0099564 281 📰

# Figure 8-6. Format of 8-Bit Timer Mode Control Register 52

| Symbol | $\overline{\mathcal{I}}$ | 6      | 5 | 4      | 3     | 2     | 1      | ٥     |
|--------|--------------------------|--------|---|--------|-------|-------|--------|-------|
| TMC52  | TCE52                    | TMC526 | 0 | TMC524 | LVS52 | LVR52 | TMC521 | TOE52 |

| Address | On reset | R/W |
|---------|----------|-----|
| FF78H   | 04H      | R/W |

| TCE52 | Controls count operation of TM52.                                          |
|-------|----------------------------------------------------------------------------|
| 0     | Disables count operation after clearing counter to 0 (disables prescaler). |
| 1     | Starts counting.                                                           |

| TMC526 | Selects operating mode of TM52.                         |
|--------|---------------------------------------------------------|
| 0      | Clears and starts on coincidence between TM52 and CR52. |
| 1      | PWM (free running) mode                                 |

| TMC52 | Selects single mode or cascade mode. |
|-------|--------------------------------------|
| 0     | Single mode                          |
| 1     | Cascade mode (connected to TM51)     |

| LVS52 | LVR52 | Sets status of timer output F/F. |
|-------|-------|----------------------------------|
| 0     | 0     | Not affected                     |
| 0     | 1     | Resets timer output F/F (to 0).  |
| 1     | 0     | Sets timer output F/F (to 1).    |
| 1     | 1     | Setting prohibited               |

| TMC521 | Other than PWM<br>mode (TMC526 = 0) | PWM mode<br>(TMC526 = 1) |
|--------|-------------------------------------|--------------------------|
|        | Controls timer F/F.                 | Selects active level.    |
| 0      | Disables inverted operation.        | High active              |
| 1      | Enables inverted operation.         | Low active               |

| TOE52 | Controls timer output.       |
|-------|------------------------------|
| 0     | Disables output (port mode). |
| 1     | Enables output.              |

- Remarks 1. The PWM output is at the inactive level in the PWM mode because TCE52 = 0.
  - 2. If LVS52 and LVR52 are read immediately after data has been set, these bits are 0.

## (2) Timer clock select registers 50, 51, and 52 (TCL50, TCL51, and TCL52)

These registers specify the count clock of the 8-bit timer counters 50, 51, and 52 (TM50, TM51, and TM52) and the valid edges of TI50, TI51, and TI52 inputs.

TCL50, TCL51, and TCL52 are set by using an 8-bit memory manipulation instruction.

When the RESET signal is input, these registers are set to 00H.

Figures 8-7 to 8-9 show the formats of TCL50, TCL51, and TCL52.

#### R/W Symbol 7 6 5 4 3 2 1 0 Address On reset TCL50 TCL502 TCL501 TCL500 FF69H 00H R/W 0 0 0 0 0 TCL502 TCL501 TCL500 Selects count clock. 0 0 0 Falling edge of TI50 0 0 Rising edge of TI50 1 0 1 0 fx/2 (4.19 MHz) 0 1 1 fx/23 (1.05 MHz) 1 0 0 fx/25 (262 kHz) 1 0 1 fx/27 (65.5 kHz) 1 1 0 fx/2º (16.4 kHz) 1 1 1 fx/211 (4.09 kHz)

## Figure 8-7. Format of Timer Clock Select Register 50

Cautions 1. Before rewriting the data of TCL50, stop the timer operation once. 2. Be sure to clear bits 3 to 7 of TCL50 to 0.

**Remark** (): at fx = 8.38-MHz operation

## 🖬 6427525 0099566 054 🌆

| Symbol | - | - | 5 |   | - | 2      | -      | •      | Address | On reset | R/W |
|--------|---|---|---|---|---|--------|--------|--------|---------|----------|-----|
| TCL51  | 0 | 0 | 0 | 0 | 0 | TCL512 | TCL511 | TCL510 | FF71H   | 00Н      | R/W |

| _      |        |        |                              |
|--------|--------|--------|------------------------------|
| TCL512 | TCL511 | TCL510 | Selects count clock.         |
| 0      | 0      | 0      | Falling edge of TI51         |
| 0      | 0      | 1      | Rising edge of TI51          |
| 0      | 1      | 0      | fx (8.38 MHz)                |
| 0      | 1      | 1      | fx/2 (4.19 MHz)              |
| 1      | 0      | 0      | fx/2² (2.1 MHz)              |
| 1      | 0      | 1      | fx/2 <sup>3</sup> (1.05 MHz) |
| 1      | 1      | 0      | fx/24 (524 kHz)              |
| 1      | 1      | 1      | fx/2 <sup>5</sup> (262 kHz)  |

# Cautions 1. Before rewriting the data of TCL51, stop the timer operation once. 2. Be sure to clear bits 3 to 7 of TCL51 to 0.

**Remark** (): at fx = 8.38-MHz operation

# Figure 8-9. Format of Timer Clock Select Register 52

| Symbol |   |   | - |   | - | -      |        | •      | Address | On reset | R/W |
|--------|---|---|---|---|---|--------|--------|--------|---------|----------|-----|
| TCL52  | 0 | 0 | 0 | 0 | 0 | TCL522 | TCL521 | TCL520 | FF79H   | 00H      | R/W |

| TCL522 | TCL521 | TCL520 | Selects count clock.         |
|--------|--------|--------|------------------------------|
| 0      | 0      | 0      | Falling edge of TI52         |
| 0      | 0      | 1      | Rising edge of TI52          |
| 0      | 1      | 0      | fx/24 (524 kHz)              |
| 0      | 1      | 1      | fx/2⁵ (262 kHz)              |
| 1      | 0      | 0      | fx/2 <sup>6</sup> (131 kHz)  |
| 1      | 0      | 1      | fx/2 <sup>7</sup> (65.5 kHz) |
| 1      | 1      | 0      | fx/2ª (32.7 kHz)             |
| 1      | 1      | 1      | fx/2º (16.4 kHz)             |

Cautions 1. Before rewriting the data of TCL52, stop the timer operation once. 2. Be sure to clear bits 3 to 7 of TCL52 to 0.

**Remark** (): at fx = 8.38-MHz operation

🖬 6427525 0099567 T90 🖿

# 8.4 Operation of 8-Bit Timer/Event Counter

#### 8.4.1 Operation as interval timer (8-bit operation)

The 8-bit timer/event counters operate as interval timers that repeatedly generate an interrupt at time intervals specified by the count values set to the corresponding 8-bit compare registers (CR5n) in advance.

When the count values of the 8-bit timer counter (TM5n) coincide with the values set to the corresponding compare register CR5n, the value of TM5n is cleared to 0, TM5n continues counting, and at the same time, interrupt request signal (INTTM5n) is generated.

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

#### <Setting>

<1> Set each register.

- TCL5n: Selects count clock.
- CR5n: Compare value
- TMC5n: Selects clear and start mode on coincidence between TM5n and CR5n (TMC5n = 0000xxx0B x = don't care).
- <2> The count operation is started when TCE5n is set to 1.
- <3> INTTM5n occurs when the values of TM5n and CR5n coincide (TM5n is cleared to 00H).
- <4> After that, INTTM5n repeatedly occurs at the same interval. To stop the count operation, clear TCE5n to 0.

Remark n = 0 to 2





## Figure 8-10. Interval Timer Operation Timing (2/3)

(b) When CR5n = 00H









| 6427525 0099569 863 🎟

Figure 8-10. Interval Timer Operation Timing (3/3)





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



Remark n = o to 2



## 8.4.2 Operation as external event counter

The external event counter counts the number of clock pulses externally input to the TI50/P24 to TI52/P26 pins by using the 8-bit timer counter (TM5n).

Each time the valid edge specified by the timer clock select register (TCL5n) is input, the value of TM5n is incremented. Either the rising edge or falling edge can be specified as the valid edge.

When the count value of TM5n coincide with the values of the corresponding 8-bit compare register (CR5n), TM5n is cleared to 0, and interrupt request signal (INTTM5n) is generated.

## Remark n = 0 to 2





Remark N = 00H to FFH n = 0 to 2

# 6427525 0099571411 🖿

## 8.4.3 Square wave output operation (8-bit resolution)

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

#### <Setting>

<1> Set each register.

- Clear the port latch and port mode register 2 to "0".
- TCL5n: Selects count clock
- CR5n: Compare value
- TMC5n: Clear and start mode on coincidence between TM5n and CR5n

| LVS5n | LVR5n | Sets status of timer output F/F |
|-------|-------|---------------------------------|
| 1     | 0     | High-level output               |
| 0     | 1     | Low-level output                |

Enables inverting timer output F/F

- Timer output enabled  $\rightarrow$  TOE5n = 1
- <2> The count operation is started if TCE5n is set to 1.
- <3> The timer output F/F is inverted if the values of TM5n and CR5n coincide. INTTM5n occurs and TM5n is cleared to 00H.
- <4> After that, the timer output F/F is inverted at the same interval, and square wave is output from TO5n.

Remark n = 0 to 2

112

# 6427525 0099572 358 📟

Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### 8.4.4 8-bit PWM output operation

The PWM output operation is performed when bit 6 (TMC5n6) of the 8-bit timer mode control register (TMC5n) is set to "1".

The pulse with a duty factor determined by the value set to the 8-bit compare register (CR5n) is output from TO5n. Set the width of the active level of the PWM pulse to CR5n. The active level can be selected from bit 1 (TMC5n1) of TMC5n.

The count clock can be selected by bits 0 to 2 (TCL5n0 to TCL5n2) of the timer clock select register (TCL5n). The PWM output can be enabled or disabled by bit 0 (TOE5n) of TMC5n.

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

#### <Setting>

- <1> Clear the port latch and port mode register 2 to "0".
- <2> Set an active level width with the 8-bit compare register (CR5n).
- <3> Select a count clock with the timer clock select register (TCL5n).
- <4> Set an active level by using the bit 1 (TMC5n1) of TMC5n.
- <5> The count operation is started when bit 7 (TCE5n) of TMC5n is set to "1". To stop the count operation, clear TCE5n to "0".

#### <PWM output operation>

- <1> When the count operation is started, an inactive level is output as the PWM output (output from TO5n) until an overflow occurs.
- When an overflow occurs, the active level set in step <1> above is output. This active level is continuously output until the value of CR5n coincides with the count value of an 8-bit timer register (TM5n).
- <3> An inactive level is output as the PWM output after the value of CR5n has coincided with the count value of TM5n, until an overflow occurs again.
- <4> After that, <2> and <3> are repeated until the count operation is stopped.
- <5> When the count operation is stopped by clearing TCE5n to 0, the PWM output becomes inactive.

**Remark** n = 0 to 2

## 🗖 6427525 0099573 294 🖿







Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### Figure 8-13. Operation Timing When CR5n is Changed

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



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



(c) If value of CR5n is changed from N to M during 2 clocks (00H, 01H) immediately after TM5n overflows





6427525 0099575 067 🖿

## 8.4.5 Operation as interval timer (16-bit operation)

### (1) Cascade (16-bit timer) mode (TM50 and TM51)

The 16-bit resolution timer/counter mode is set by setting bit 4 (TMC514) of the 8-bit timer mode control register 51 (TMC51) to "1".

In this mode, TM50 and TM51 operate as a 16-bit interval timer that repeatedly generates an interrupt at intervals specified by the count value set in advance to 8-bit compare registers (CR50 and CR51).

#### <Setting>

<1> Set each register.

• TCL50:

TM51, which is connected in cascade, does not have to be set.

- CR50 and CR51; Compare values (Each compare value can be set in a range of 00H to FFH).
- TMC50 and TMC51: Select the mode that clears and starts the timer on coincidence between TM50

and CR50 (TM51 and CR51).

TM50 selects a count clock.

TM50  $\rightarrow$  TMC50 = 0000xxx0B x: don't care

TM51  $\rightarrow$  TMC51 = 0001xxx0B x: don't care

- <2> By setting TCE51 to 1 for TMC51 first, and then setting TCE50 to 1 for TMC50, the count operation is started.
- <3> When the value of TM50 connected in cascade coincides with the value of CR50, TM50 generates INTTM50 (TM50 and TM51 are cleared to 00H).
- <4> After that, INTTM50 is repeatedly generated at the same interval.
- Cautions 1. Be sure to set the compare registers (CR50 and CR51) after stopping the timer operation.
  2. Even if the timers are connected in cascade, TM51 generates INTTM51 when the count value of TM51 coincides with the value of CR51. Be sure to mask TM51 to disable it from generating an Interrupt.
  - 3. To set TCE50 and TCE51, first manipulate TM51 and then TM50.
  - 4. Counting can be started or stopped by setting or clearing only TCE50 of TM50 to 1 or 0.

Figure 8-14 shows an example of timing in the 16-bit resolution cascade mode.



64275250099576 TT3 🖿

Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### (2) Cascade (16-bit timer) mode (TM51 and TM52)

The 16-bit resolution timer/counter mode is set by setting bit 4 (TMC524) of the 8-bit timer mode control register 52 (TMC52) to "1".

In this mode, TM51 and TM52 operate as a 16-bit interval timer that repeatedly generates an interrupt at intervals specified by the count value set in advance to 8-bit compare registers (CR51 and CR52).

### <Setting>

<1> Set each register.

• TCL51:

TM51 selects a count clock.

TM52, which is connected in cascade, does not have to be set.

- Compare values (Each compare value can be set in a range of 00H to FFH). CR51 and CR52:
- TMC51 and TMC52: Select the mode that clears and starts the timer on coincidence between TM51 and CR51 (TM52 and CR52).

TM51  $\rightarrow$  TMC51 = 0000xxx0B x: don't care

 $TM52 \rightarrow TMC52 = 0001xxx0B x: don't care$ 

- Sy setting TCE52 to 1 for TMC52 first, and then setting TCE51 to 1 for TMC51, the count operation is started.
- <3> When the value of TM51 connected in cascade coincides with the value of CR51, TM51 generates INTTM51 (TM51 and TM52 are cleared to 00H).
- <4> After that, INTTM51 is repeatedly generated at the same interval.
- Cautions 1. Be sure to set the compare registers (CR51 and CR52) after stopping the timer operation.
  - 2. Even if the timers are connected in cascade, TM52 generates INTTM52 when the count value of TM52 coincides with the value of CR52. Be sure to mask TM52 to disable it from generating an interrupt.
  - 3. To set TCE51 and TCE52, first manipulate TM52 and then TM51.
  - 4. Counting can be started or stopped by setting or clearing only TCE51 of TM51 to 1 or D.

Figure 8-15 shows an example of timing in the 16-bit resolution cascade mode.

# Figure 8-15. 16-Bit Resolution Cascade Mode (with TM51 and TM52)



## 8.5 Notes on Using 8-Bit Timer/Event Counters

### (1) Error on starting timer

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



## Remark n = 0 to 2

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

If a new value of an 8-bit compare register (CR5n) is less than the value of the corresponding 8-bit timer counter (TM5n), TM5n continues counting, overflows, and restarts counting from 0. Therefore, if the new value of CR5n (M) is less than their old value (N), it is necessary to restart the timers after changing the value of CR5n.

Figure 8-17. Timing after Changing Values of Compare Registers during Timer Count Operation



Caution Except when TI5n input is selected, be sure to clear TCE5n to 0 before setting the STOP mode.

Remark N > X > Mn = 0 to 2

## (3) Reading TM5n during timer operation

Because the count clock is stopped when TM5n is read during operation, select a count clock with a waveform whose high-/low-level are longer than two CPU clock cycles. For example, in the case of a CPU clock (fcru) equal to fx, TM5n can be read as long as the selected count clock is fx/4 or lower.

Remark n = 0 to 2



# 9.1 Functions of Watchdog Timer

The watchdog timer has the following functions:

- Watchdog timer
- Interval timer
- Oscillation stabilization time specification
- Caution Select the watchdog timer mode or interval timer mode by using the watchdog timer mode register (WDTM). (The watchdog timer and interval timer cannot be used simultaneously.)

#### (1) Watchdog timer mode

The watchdog timer is used to detect inadvertent program loop. When the inadvertent loop is detected, a non-maskable interrupt or the RESET signal can be generated.

| Inadvertent Loop<br>Detection Time | At fx = 8.38 MHz | Inadvertent Loop<br>Detection Time | At fx = 8.38 MHz |
|------------------------------------|------------------|------------------------------------|------------------|
| $2^{12} \times 1/f_x$              | 488.8 μs         | $2^{16} \times 1/f_{x}$            | 7.82 ms          |
| $2^{13} \times 1/fx$               | 977.6 μs         | $2^{17} \times 1/f_{X}$            | 15.6 ms          |
| $2^{14} \times 1/f_{x}$            | 1.96 ms          | 2 <sup>18</sup> × 1/fx             | 31.3 ms          |
| 2 <sup>15</sup> × 1/fx             | 3.91 ms          | $2^{20} \times 1/f_{X}$            | 125.1 ms         |

# Table 9-1. Inadvertent Loop Detection Time of Watchdog Timer

Remark fx: system clock oscillation frequency

## (2) Interval timer mode

When the watchdog timer is used as an interval timer, it generates an interrupt at time intervals set in advance.

| Interval Time           | At fx = 8.38 MHz | Interval Time           | At fx = 8.38 MHz |
|-------------------------|------------------|-------------------------|------------------|
| $2^{12} \times 1/fx$    | 488.8 μs         | $2^{16} \times 1/fx$    | 7.82 ms          |
| $2^{13} \times 1/f_X$   | 977.6 μs         | $2^{17} \times 1/f_{X}$ | 15.6 ms          |
| $2^{14} \times 1/f_{x}$ | 1.96 ms          | 2 <sup>18</sup> × 1/fx  | 31.3 ms          |
| 2 <sup>15</sup> × 1/fx  | 3.91 ms          | $2^{20} \times 1/f_{x}$ | 125.1 ms         |

#### Table 9-2. Interval Time

Remark fx: system clock oscillation frequency

# 9.2 Configuration of Watchdog Timer

The watchdog timer consists of the following hardware:

Table 9-3. Configuration of Watchdog Timer

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





**6**427525 0099580 424 **F** 

# 9.3 Registers Controlling Watchdog Timer

The following three registers control the watchdog timer:

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

#### (1) Watchdog timer clock select register (WDCS) (refer to Figure 9-2)

This register sets the watchdog timer and overflow time of interval timer. WDCS is set by an 8-bit memory manipulation instruction. This register is set to 00H when the RESET signal is input.



# Figure 9-2. Format of Watchdog Timer Clock Select Register

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

2. ( ): at fx = 8.38-MHz operation

# (2) Watchdog timer mode register (WDTM)

This register sets an operation mode of the watchdog timer, and enables/disables counting of the watchdog timer.

WDTM is set by a 1-bit or 8-bit memory manipulation instruction. This register is set to 00H when the  $\overrightarrow{\text{RESET}}$  signal is input.



# Figure 9-3. Format of Watchdog Timer Mode Register

 The watchdog timer starts operating as an interval timer as soon as the RUN bit has been set to 1.

Notes 1. Once WDTM3 and WDTM4 have been set to 1, they cannot be cleared to 0 by software.

- 3. Once RUN has been set to 1, it cannot be cleared to 0 by software. Therefore, when counting is started, it cannot be stopped by any means other than RESET input.
- Caution When the watchdog timer is cleared by setting 1 to RUN, the actual overflow time is up to 0.5% shorter than the time set by the watchdog timer clock select register.

Remark x: don't care

122

## 🖬 6427525 0099582 2T7 🖿

Powered by ICminer.com Electronic-Library Service CopyRight 2003

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

This register selects the oscillation stabilization time that elapses since the RESET signal has been applied or the STOP mode has been released, until oscillation is stabilized.

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

This register is set to 04H when the RESET signal is input. Therefore, to release the STOP mode by inputting the RESET signal, the ime required to release the mode is 2<sup>17</sup>/fx.



Figure 9-4. Format of Oscillation Stabilization Time Select Register

Remarks 1. fx: system clock oscillation frequency

2. ( ): at fx = 8.38-MHz operation

# 🖬 6427525 0099583 133 🖿

# 9.4 Operation of Watchdog Timer

## 9.4.1 Operation as watchdog timer

The watchdog timer detects an inadvertent program loop when bit 4 (WDTM4) of the watchdog timer mode register (WDTM) is set to 1.

The inadvertent loop detection time interval of the watchdog timer can be selected by bits 0 to 2 (WDCS0 to WDCS2) of the watchdog timer clock select register (WDCS). By setting bit 7 (RUN) of WDTM to 1, the watchdog timer is started. Set RUN to 1 within the set inadvertent loop detection time interval after the watchdog timer has been started. By setting RUN to 1, the watchdog timer can be cleared and started counting. If RUN is not set to 1, and the inadvertent loop detection time is exceeded, the system is reset or a non-maskable interrupt is generated by the value of bit 3 (WDTM3) of WDTM.

The watchdog timer continues operation in the HALT mode, but stops in the STOP mode. Therefore, set RUN to 1 before entering the STOP mode to clear the watchdog timer, and then execute the STOP instruction.

#### Cautions 1. The actual inadvertent loop detection time may be up to 0.5% shorter than the set time.

2. The count operation of the watchdog timer is stopped when the subsystem clock is selected as the CPU clock.

| TCL22 | TCL21 | TCL20 | Inadvertent Loop Detection Time | At fx = 8.38 MHz |
|-------|-------|-------|---------------------------------|------------------|
| 0     | 0     | 0     | $2^{12} \times 1/f_x$           | 488.8 μs         |
| 0     | 0     | 1     | $2^{13} \times 1/fx$            | 977.6 μs         |
| 0     | 1     | 0     | $2^{14} \times 1/f_{X}$         | 1.96 ms          |
| 0     | 1     | 1     | $2^{15} \times 1/t_{X}$         | 3.91 ms          |
| 1     | 0     | O     | $2^{16} \times 1/f_{X}$         | 7.82 ms          |
| 1     | 0     | 1     | $2^{17} \times 1/f_{X}$         | 15.6 ms          |
| 1     | 1     | 0     | 2 <sup>18</sup> × 1/fx          | 31.3 ms          |
| 1     | 1     | 1     | 2 <sup>20</sup> × 1/fx          | 125.1 ms         |

6427525 0099584 07T 📰

Table 9-4. Inadvertent Loop Detection Time of Watchdog Timer

Remark fx: system clock oscillation frequency

Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### 9.4.2 Operation as interval timer

When bit 4 (WDTM4) of the watchdog timer mode register (WDTM) is set to 0, the watchdog timer also operates as an interval timer that repeatedly generates an interrupt at time intervals specified by a count value set in advance.

Bits 0 to 2 (WDCS0 to WDCS2) of the watchdog timer clock select register (WDCS) can be used to select interval time of interval timer. When bit 7 (RUN) of WDTM is set to 1, the watchdog timer starts operating as an interval timer.

In the interval timer mode, the interrupt mask flag (WDTMK) and priority specification flag (WDTPR) are valid, and a maskable interrupt (INTWDT) can be generated. The default priority of INTWDT is set the highest of all the maskable interrupts.

The interval timer continues operation in the HALT mode, but stops in the STOP mode. Therefore, set bit 7 of WDTM (RUN) to 1 before entering the STOP mode to clear the interval timer, and then execute the STOP instruction.

Cautions: 1. Once bit 4 (WDTM4) of WDTM has been set to 1 (when the watchdog timer mode is selected), the interval timer mode is not set, unless the RESET signal is input.

2. The interval time immediately after it has been set by WDTM may be up to 0.5% shorter than the set time.

| WDCS2 | WDCS1 | WDCS0 | Interval Time           | At fx = 8.38 MHz |
|-------|-------|-------|-------------------------|------------------|
| 0     | 0     | 0     | $2^{12} \times 1/fx$    | 488.8 μs         |
| 0     | 0     | 1     | $2^{13} \times 1/fx$    | 977.6 μs         |
| 0     | 1     | 0     | $2^{14} \times 1/fx$    | 1.96 ms          |
| 0     | 1     | 1     | $2^{15} \times 1/fx$    | 3.91 ms          |
| 1     | 0     | 0     | $2^{16} \times 1/f_{x}$ | 7.82 ms          |
| 1     | 0     | 1     | $2^{17} \times 1/fx$    | 15.6 ms          |
| 1     | 1     | 0     | 2 <sup>18</sup> × 1/fx  | 31.3 ms          |
| 1     | 1     | 1     | $2^{20} \times 1/fx$    | 125.1 ms         |

Table 9-5. Interval Time of Interval Timer

Remark fx: system clock oscillation frequency

# 🖬 6427525 0099585 TO6 📰

126

PAGE(S) INTENTIONALLY BLANK

### CHAPTER 10 8-BIT A/D CONVERTER (µPD780924 SUBSERIES)

# 10.1 Function of A/D Converter

The A/D converter converts an analog input signal into a digital value, and consists of eight channels (ANIO to ANI7) with a resolution of 8 bits.

This A/D converter is of successive approximation type, and the result of conversion is held by an 8-bit A/D conversion result register (ADCR0).

A/D conversion can be started in the following two ways:

#### (1) Hardware start

Conversion is started by trigger input (P03) (rising, falling, both rising and falling edges can be specified).

#### (2) Software start

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

One channel of analog input is selected from ANI0 to ANI7 and A/D conversion is executed. The A/D conversion is stopped, if it has been started by means of hardware start, after the conversion has been completed, and an interrupt request (INTAD0) is generated. When A/D conversion has been started by means of software start, conversion is repeatedly performed. Each time conversion has been completed once, an interrupt request (INTAD0) is generated.

## 10.2 Configuration of A/D Converter

The A/D converter consists of the following hardware:

| item             | Configuration                                                                                |
|------------------|----------------------------------------------------------------------------------------------|
| Analog input     | 8 channels (ANI0 to ANI7)                                                                    |
| Control register | A/D converter mode register 0 (ADM0)<br>Analog input channel specification register 0 (ADS0) |
| Register         | Successive approximation register (SAR)<br>A/D conversion result register (ADCR0)            |

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



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

Note Specify the valid edge by using bit 3 of the EGP and EGN registers (refer to Figure 13-5 Formats of External Interrupt Rising Edge Enable Register and External Interrupt Falling Edge Enable Register).

## (1) Successive approximation register (SAR)

This register compares the voltage value of analog input with the value of a voltage tap (compare voltage) from the series resistor string, and holds the result of the comparison starting from the most significant bit (MSB).

When the result is held down to the least significant bit (LSB) (end of A/D conversion), the contents of SAR are transferred to the A/D conversion result register.

#### (2) A/D conversion result register (ADCR0)

This register holds the result of A/D conversion result. Each time A/D conversion has been completed, the result of the conversion is loaded to this register from the successive approximation register. ADCR0 can be read by an 8-bit memory manipulation instruction.

The contents of this register become undefined when the RESET signal is input.

#### (3) Sample and hold circuit

The sample and hold circuit samples analog input signals sequentially sent from the input circuit on a oneby-one basis, and sends the sampled signals to the voltage comparator. This circuit holds the sampled analog input voltage value during A/D conversion.

#### (4) Voltage comparator

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

#### (5) Series resistor string

The series resistor string is connected between AVREF and AVss and generates a voltage to be compared with an analog input.

#### (6) ANIO to ANI7 pins

These are eight channels of analog input pins of the A/D converter. They input analog signals that are converted to digital values.

Caution Observe the specified input voltage range of ANI0 to ANI7. If a voltage of AVREF or higher, or AVss or lower (even within the range of absolute maximum ratings) is applied to a channel, the converted value of that channel becomes undefined, or the converted value of the other channels may be affected.

# (7) AVREF pin

This pin inputs a reference voltage to the A/D converter. Based on the voltage applied between AVREF and AVss, the signal input to ANI0 to ANI7 is converted into a digital signal.

#### (8) AVss pin

This is a ground pin of the A/D converter. Be sure to use this pin at the same voltage as that on the Vsso pin always even when the A/D converter is not used.

# (9) AVoo pin

This is an analog pin of the A/D converter. Be sure to use this pin at the same voltage as that on the VDCO pin always even when the A/D converter is not used.

# **10.3 Registers Controlling A/D Converter**

The following two registers control the A/D converter:

- A/D converter mode register 0 (ADM0)
- Analog input channel specification register 0 (ADS0)

## (1) A/D converter mode register 0 (ADM0)

This register sets conversion time of an analog input to be converted into a digital value, starts/stops conversion operation, and sets an external trigger.

ADM0 is set by a 1-bit or 8-bit memory manipulation instruction.

This register is set to 00H when the RESET signal is input.

# Figure 10-2. Format of A/D Converter Mode Register 0

| Symbol |       |      |      |      |      |       |       |   | Address | On reset | R/W |
|--------|-------|------|------|------|------|-------|-------|---|---------|----------|-----|
| ADM0   | ADCS0 | TRG0 | FR02 | FR01 | FR00 | EGA01 | EGA00 | 0 | FF80H   | 00H      | RW  |

| ADCS0 | Controls A/D conversion operation. |
|-------|------------------------------------|
| 0     | Stops operation.                   |
| 1     | Enables operation.                 |

| TRG0 | Selects software/hardware start. |
|------|----------------------------------|
| 0    | Software start                   |
| 1    | Hardware start                   |

| FR02   | FR01 | FR00 | Selects A/D conversion time. |
|--------|------|------|------------------------------|
| 0      | 0    | 0    | 144/fx (17.2 μs)             |
| 0      | 0    | 1    | 120/fx (14.3 μs)             |
| 1      | 0    | 0    | 288/fx (34.4 μs)             |
| 1      | 0    | 1    | 240/fx (28.6 μs)             |
| 1      | 1    | 0    | 192/fx (22.9 μs)             |
| Others | 5    |      | Setting prohibited           |

| EGA01 | EGA00 | Specifies valid edge of external trigger. |
|-------|-------|-------------------------------------------|
| 0     | 0     | No edge is detected.                      |
| 0     | 1     | Detects falling edge.                     |
| 1     | 0     | Detects rising edge.                      |
| 1     | 1     | Detects both rising and falling edges.    |

Caution Do not set the A/D conversion time to less than 14  $\mu s.$ 

**Remark** (): at fx = 8.38-MHz operation



# (2) Analog input channel specification register 0 (ADS0)

This register sets the input port of analog voltage to be converted into a digital value. ADS0 is set by an 8-bit memory manipulation instruction. This register is set to 00H when the RESET signal is input.

| Symbol | 7          | 6     | 5     | 4    | 3        | 2         | 1        | 0          | Address | On reset | R/W |
|--------|------------|-------|-------|------|----------|-----------|----------|------------|---------|----------|-----|
| ADS0   | 0          | 0     | 0     | 0    | 0        | ADS02     | ADS01    | ADS00      | FF81H   | 00H      | R/W |
|        | • <u> </u> | , ·   |       |      |          |           |          | <u>'</u> I |         |          |     |
|        | ADS02      | ADS01 | ADS00 | Spec | cifies a | analog ir | nput cha | annel.     |         |          |     |
|        | 0          | 0     | 0     | ANIC | )        |           |          |            |         |          |     |
|        | 0          | 0     | 1     | ANI1 |          |           |          |            |         |          |     |
|        | 0          | 1     | 0     | ANI2 | 2        |           |          |            |         |          |     |
|        | 0          | 1     | 1     | ANIS | 3        |           |          |            |         |          |     |
|        | 1          | 0     | 0     | ANI4 | <b>i</b> |           |          |            |         |          |     |
|        | 1          | 0     | 1     | ANI5 | 5        |           |          |            |         |          |     |
|        | 1          | 1     | 0     | ANI6 | 5        |           |          |            |         |          |     |
|        | 1          | 1     | 1     | ANI7 |          |           |          |            |         |          |     |

Figure 10-3. Format of Analog Input Channel Specification Register 0

132

# 🔲 6427525 0099592 146 🖿

Powered by ICminer.com Electronic-Library Service CopyRight 2003

# 10.4 Operation of A/D Converter

# 10.4.1 Basic operation of A/D converter

- <1> Select one channel for A/D conversion by using the analog input channel specification register 0 (ADS0).
- <2> The voltage input to the selected analog input channel is sampled by the sample and hold circuit.
- <3> When the voltage has been sampled for a specific time, the sample and hold circuit enters the hold status, and holds the input analog voltage until A/D conversion is completed.
- <4> Set bit 7 of the successive approximation register (SAR). The tap selector selects (1/2)AVREF as the voltage tap of the series resistor string.
- <5> The voltage difference between the voltage tap of the series resistor string and the analog input is compared by the voltage comparator. If the analog input is higher than (1/2)AVREF, the MSB of SAR remains set. If it is less than (1/2)AVREF, the MSB is reset.
- <6> Next, bit 6 of SAR is automatically set, and the next voltage difference is compared. Here the voltage tap of the series resistor string is selected as follows, according to the value of bit 7 to which the result of the first comparison has been already set.
  - Bit 7 = 1 : (3/4)AVREF
  - Bit 7 = 0 : (1/4)AVREF

This voltage tap and analog input voltage are compared, and bit 6 of SAR is manipulated as follows, according to the result of the comparison:

- Analog input voltage ≥ voltage tap : bit 6 = 1
- Analog input voltage ≤ voltage tap : bit 6 = 0
- <7> In this way, all the bits of SAR, including bit 0, are compared.
- <8> When all the 8 bits of SAR have been compared, SAR holds the valid digital result whose values are transferred and latched to the A/D conversion result register (ADCR0).

At the same time, an A/D conversion end interrupt request (INTAD0) can be generated.

6427525 0099593 082 🎟





The A/D conversion is performed continuously, until the bit 7 of ADM0 (ADCS0) is reset to 0 by software. If the data of the ADM0 register or ADS0 register is rewritten during the A/D conversion, the conversion is initialized. If the ADCS0 bit is set to 1 at this time, conversion is performed again from the start.

The contents of the ADCR0 register become undefined when the RESET signal is input.

134

🛚 6427525 0099594 TJ9 🖿

## 10.4.2 Input voltage and conversion result

The relation between the analog voltage input to the analog input pins (ANI0 to ANI7) and A/D conversion result (value stored to A/D conversion result register (ADCR0)) is as follows:

$$ADCR0 = INT \left(\frac{V_{IN}}{AV_{REF}} \times 256 + 0.5\right)$$

or,

$$(\text{ADCR0} - 0.5) \times \frac{\text{AV}_{\text{REF}}}{256} \le \text{Vin} < (\text{ADCR0} + 0.5) \times \frac{\text{AV}_{\text{REF}}}{256}$$

Remark INT() : function returning integer of value in ()

VIN : analog input voltage AVREF : AVREF pin voltage ADCR0: value of A/D conversion result register (ADCR0)

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

Figure 10-5. Relations between Analog Input Voltage and A/D Conversion Result



# 10.4.3 Operation mode of A/D converter

The A/D converter operates in the select mode only. One analog input channel is selected from ANI0-ANI7 for A/D conversion by using the analog input channel specification register 0 (ADS0).

The A/D conversion can be started in the following two ways:

- Hardware start : Conversion is started by trigger input (P03).
- Software start : Conversion is started by setting ADM0.

The result of the A/D conversion is stored in the A/D conversion result register (ADCR0), and at the same time, an interrupt request signal (INTAD0) is generated.

#### (1) A/D conversion operation by hardware start

The A/D conversion stands by when both bits 6 (TRG0) and 7 (ADCS0) of A/D converter mode register (ADM0) are set to 1. When an external trigger signal (P03) is input, the voltage applied to the analog input pin specified by ADS0 is converted into a digital value.

When the A/D conversion has been completed, the result of the conversion is stored in the A/D conversion result register (ADCR0), and an interrupt request signal (INTAD0) is generated. Once the A/D conversion has been started and when one A/D conversion has been completed, the next A/D conversion is not started unless a new external trigger signal is input.

If data whose ADCS0 is 1 is written again to ADM0 during A/D conversion, the AD conversion under execution is stopped, and stands by until a new external trigger signal is input. When the external trigger signal is input, A/D conversion is performed again from the start.

When 0 is written to the ADCS0 bit of ADM0 during A/D conversion, the conversion is immediately stopped.



6427525 0099596 891 🗰

# Figure 10-6. A/D Conversion by Hardware Start (When falling edge is specified)

#### (2) A/D conversion by software start

By setting bit 6 (TRG0) of the A/D converter mode register (ADM0) to 0 and setting bit 7 (ADCS0) to 1, the voltage applied to the analog input pin specified by ADS0 is converted into digital values.

When the A/D conversion has been completed, the result of the conversion is stored in the A/D conversion result register (ADCR0), and an interrupt request signal (INTAD0) is generated. When the A/D conversion has been started once, and one A/D conversion has been completed, the next A/D conversion is immediately started. In this way, A/D conversion is repeatedly executed until new data is written to ADM0.

If data whose ADCS0 is 1 is written again to ADM0 during A/D conversion, the conversion under execution is stopped, and the A/D conversion of the newly written data is started.

If data whose ADCS0 is 0 is written to ADM0 during A/D conversion, the conversion is immediately stopped.



Figure 10-7. A/D Conversion by Software Start

Remark n = 0, 1, ..., 7 m = 0, 1, ..., 7

#### | 6427525 0099597 728 🎟

# 10.5 Notes on A/D Converter

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

The A/D converter stops operating in the standby mode. At this time, the current consumption can be reduced by stopping the conversion operation (by clearing bit 7 (ADCS0) of the A/D converter mode register 0 (ADM0) to 0). An example of reducing the current consumption in standby mode is shown in Figure 10-8.

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



# (2) ANI0 to ANI7 input range

Observe the rated range of the ANI0 to ANI7 input voltage. If a voltage of AVREF or higher, or AVss or lower (even in the range of absolute maximum ratings) is input to an analog input channel, the converted value of that channel becomes undefined. In addition, the converted values of the other channels may also be affected.

- (3) Conflicting operations
  - <1> Conflict between writing A/D conversion result register (ADCR0) on completion of conversion and reading ADCR0 by instruction

Reading ADCR0 takes precedence. After it has been read, a new conversion result is written to ADCR0.

- <2> Conflict between writing ADCR0 on completion of conversion and external trigger signal input The external trigger signal is not accepted during A/D conversion. Therefore, the external trigger signal is not accepted while ADCR0 is written.
- <3> Conflict between writing ADCR0 on completion of conversion and writing A/D converter mode register 0 (ADM0) or writing analog input channel specification register 0 (ADS0) Writing ADM0 or ADS0 takes precedence. ADCR0 is not written. The conversion end interrupt request signal (INTAD0) is not generated.

138

🔲 6427525 0099598 664 🗰

## (4) Countermeasures against noise

To keep the resolution of 8 bits, noise superimposed on the AVREF and ANIO to ANI7 pins must be suppressed as much as possible. The higher the output impedance of the analog input source, the greater the effect. To suppress noise, connecting an external capacitor as shown in Figure 10-9 is recommended.



#### Figure 10-9. Processing Analog Input Pin

#### (5) ANIO/P10 to ANI7/P17

The analog input pins (ANI0 to ANI7) are also used as input port pins (PORT 1). When A/D conversion is performed with any of ANI0 to ANI7 selected, do not execute the input instruction of PORT 1 while conversion is in progress; otherwise, the conversion resolution may be degraded. If a digital pulse is applied to the pins adjacent to the pins currently used for A/D conversion, the expected value of the A/D conversion may not be obtained due to coupling noise. Therefore, do not apply a pulse to the adjacent pins to the pin under A/D conversion.

## (6) Input impedance to AVREF pin

A series resistor string of about 21 k\Omega is connected between the AVREF and AVss pins.

If the output impedance of the reference voltage source is high, therefore, an error of the reference voltage increases by connecting the impedance in parallel with the series resistor string between the AVREF and AVss pins.

64275250099599 STO 🔳

## (7) Interrupt request flag (ADIF)

The interrupt request flag (ADIF) is not cleared even when the contents of the A/D converter mode register 0 (ADM0) are changed.

When the analog input pin is changed during A/D conversion, therefore, the chances are that the A/D conversion result of the old analog input and interrupt request flags are set immediately before the contents of ADM0 are rewritten. Consequently, ADIF may be set even if A/D conversion for the newly specified analog input pin has not yet been completed when ADIF is read immediately after ADM0 has been rewritten (refer to Figure 10-10).

To resume A/D conversion that has been once stopped, clear ADIF before resuming the conversion.





n = 0, 1, ... ..., 7

(8) AVoo pin

140

The AVpp pin is the power supply pin to the analog circuit and supplies power to the input circuit of ANI0/P10 to ANI7/P17.

Therefore, even in the application which can be switched over to backup power source, be sure to apply the same voltage as Voto as shown in Figure 10-11.



Figure 10-11. Processing of AVop Pin

# CHAPTER 11 10-BIT A/D CONVERTER (µPD780964 SUBSERIES)

# 11.1 Function of A/D Converter

The A/D converter converts an analog input signal into a digital value, and consists of eight channels (ANIO to ANI7) with a resolution of 10 bits.

This A/D converter is of successive approximation type, and the result of conversion is held by a 10-bit A/D conversion result register (ADCR0).

A/D conversion can be started in the following two ways:

#### (1) Hardware start

Conversion is started by trigger input (P03) (rising edge, falling edge, or both rising and falling edges can be specified).

#### (2) Software start

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

One channel of analog input is selected from ANI0 to ANI7 and A/D conversion is executed. The A/D conversion is stopped, if it has been started by means of hardware start, after the conversion has been completed, and an interrupt request (INTAD0) is generated. When A/D conversion has been started by means of software start, conversion is repeatedly performed. Each time conversion has been completed once, an interrupt request (INTAD0) is generated.

#### 11.2 Configuration of A/D Converter

The A/D converter consists of the following hardware:

| ltem             | Configuration                                                                                |
|------------------|----------------------------------------------------------------------------------------------|
| Analog input     | 8 channels (ANI0 to ANI7)                                                                    |
| Control register | A/D converter mode register 0 (ADM0)<br>Analog input channel specification register 0 (ADS0) |
| Register         | Successive approximation register (SAR)<br>A/D conversion result registers (ADCR0H, ADCR0L)  |

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



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

Note Specify the valid edge by using bit 3 of the EGP and EGN registers (refer to Figure 13-5 Formats of External Interrupt Rising Edge Enable Register and External Interrupt Falling Edge Enable Register).

# 6427525 0099602 915 📖

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

This register compares the voltage value of analog input with the value of a voltage tap (compare voltage) from the series resistor string, and holds the result of the comparison starting from the most significant bit (MSB).

When the result is held down to the least significant bit (LSB) (end of A/D conversion), the contents of SAR are transferred to the A/D conversion result register.

# (2) A/D conversion result register (ADCR0)

This register holds the result of A/D conversion result. Each time A/D conversion has been completed, the result of the conversion is loaded to this register from the successive approximation register. The higher 8 bits of the conversion result are stored to ADCR0H, and the lower 2 bits are stored to bits 6 and 7 of ADCR0L. ADCR0H and ADCR0L are used in combination as a 16-bit register, ADCR0, which is read by using a 16-bit memory manipulation instruction.

The contents of this register become undefined when the RESET signal is input.

## (3) Sample and hold circuit

The sample and hold circuit samples analog input signals sequentially sent from the input circuit on a oneby-one basis, and sends the sampled signals to the voltage comparator. This circuit holds the sampled analog input voltage value during A/D conversion.

#### (4) Voltage comparator

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

#### (5) Series resistor string

The series resistor string is connected between AVREF and AVss and generates a voltage to be compared with an analog input.

### (6) ANIO to ANI7 pins

These are eight channels of analog input pins of the A/D converter. They input analog signals that are converted to digital values.

Caution Observe the specified input voltage range of ANI0 to ANI7. If a voltage of AVREF or higher, or AVss or lower (even within the range of absolute maximum ratings) is applied to a channel, the converted value of that channel becomes undefined, or the converted value of the other channels may be affected.

## (7) AVREF pin

This pin inputs a reference voltage to the A/D converter. Based on the voltage applied between AVREF and AVss, the signal input to ANI0 to ANI7 is converted into a digital signal.

#### (8) AVss pin

This is a ground pin of the A/D converter. Be sure to use this pin at the same voltage as that on the Vsso pin always even when the A/D converter is not used.

6427525 0099603 851 🔳

# (9) AVoo pin

This is an analog pin of the A/D converter. Be sure to use this pin at the same voltage as that on the Voco pin always even when the A/D converter is not used.

#### 11.3 Registers Controlling A/D Converter

The following two registers control the A/D converter:

- A/D converter mode register 0 (ADM0)
- Analog input channel specification register 0 (ADS0)

#### (1) A/D converter mode register 0 (ADM0)

This register sets conversion time of an analog input to be converted into a digital value, starts/stops conversion operation, and sets an external trigger.

ADM0 is set by a 1-bit or 8-bit memory manipulation instruction.

This register is set to 00H when the RESET signal is input.

Figure 11-2. Format of A/D Converter Mode Register 0

|      |       |      |      |      |      |       |       |   | Address |     |     |
|------|-------|------|------|------|------|-------|-------|---|---------|-----|-----|
| ADM0 | ADCSO | TRG0 | FR02 | FR01 | FR00 | EGA01 | EGA00 | 0 | FF80H   | 00H | R/W |

| ADCS0 | Controls A/D conversion operation. |
|-------|------------------------------------|
| 0     | Stops operation.                   |
| 1     | Enables operation.                 |

| TRG0 | Selects software/hardware start. |
|------|----------------------------------|
| 0    | Software start                   |
| 1    | Hardware start                   |

| FR02   | FR01 | FR00 | Selects A/D conversion time. |
|--------|------|------|------------------------------|
| 0      | 0    | 0    | 144/fx (17.2 μs)             |
| 0      | 0    | 1    | 120/fx (14.3 μs)             |
| 1      | 0    | 0    | 288/fx (34.4 μs)             |
| 1      | 0    | 1    | 240/fx (28.6 μs)             |
| 1      | 1    | 0    | 192/fx (22.9 μs)             |
| Others |      |      | Setting prohibited           |

| EGA01 | EGA00 | Specifies valid edge of external trigger. |
|-------|-------|-------------------------------------------|
| 0     | 0     | No edge is detected.                      |
| 0     | 1     | Detects falling edge.                     |
| 1     | 0     | Detects rising edge.                      |
| 1     | 1     | Detects both rising and falling edges.    |

Caution Do not set the A/D conversion time to less than 14  $\mu$ s.

Remark (): at fx = 8.38-MHz operation

🖬 6427525 0099605 624 🔳

\_\_\_\_

(2) Analog input channel specification register 0 (ADS0)

This register sets the input port of analog voltage to be converted into a digital value. ADS0 is set by an 8-bit memory manipulation instruction. This register is set to 00H when the RESET signal is input.

# Figure 11-3. Format of Analog Input Channel Specification Register 0

| Symbol | 7     | 6     | 5        | 4    | з       | 2         | 1        | 0        | Address | On reset | R/W |
|--------|-------|-------|----------|------|---------|-----------|----------|----------|---------|----------|-----|
| ADS0   | 0     | 0     | 0        | 0    | 0       | ADS02     | ADS01    | ADS00    | FF81H   | 00H      | RŴ  |
|        | L     |       | <b>!</b> |      |         | - <u></u> |          | <u> </u> |         |          |     |
|        | ADS02 | ADS01 | ADS00    | Spec | ifies a | analog ir | nput cha | annel.   |         |          |     |
|        | 0     | 0     | 0        | ANIC | )       |           |          |          |         |          |     |
|        | 0     | 0     | 1        | ANI1 |         |           |          |          |         |          |     |
|        | 0     | 1     | 0        | ANI2 | ]       |           |          |          |         |          |     |
|        | 0     | 1     | 1        | ANI3 | 1       |           |          |          |         |          |     |
|        | 1     | 0     | 0        | ANI4 |         |           |          |          |         |          |     |
|        | 1     | 0     | 1        | ANI5 |         |           |          |          |         |          |     |
|        | 1     | 1     | 0        | ANI6 |         |           |          |          |         |          |     |
|        | 1     | 1     | 1        | ANI7 |         |           |          |          |         |          |     |

# 11.4 Operation of A/D Converter

# 11.4.1 Basic operation of A/D converter

- <1> Select one channel for A/D conversion by using the analog input channel specification register 0 (ADS0).
- <2> The voltage input to the selected analog input channel is sampled by the sample and hold circuit.
- <3> When the voltage has been sampled for a specific time, the sample and hold circuit enters the hold status, and holds the input analog voltage until A/D conversion is completed.
- <4> Set bit 9 of the successive approximation register (SAR). The tap selector selects (1/2)AVREF as the voltage tap of the series resistor string.
- <5> The voltage difference between the voltage tap of the series resistor string and the analog input is compared by the voltage comparator. If the analog input is higher than (1/2)AVREF, the MSB of SAR remains set. If it is less than (1/2)AVREF, the MSB is reset.
- <6> Next, bit 8 of SAR is automatically set, and the next voltage difference is compared. Here the voltage tap of the series resistor string is selected as follows, according to the value of bit 9 to which the result of the first comparison has been already set.
  - Bit 9 = 1 : (3/4)AVREF
  - Bit 9 = 0 : (1/4)AVREF

This voltage tap and analog input voltage are compared, and bit 8 of SAR is manipulated as follows, according to the result of the comparison:

- Analog input voltage ≥ voltage tap : bit 8 = 1
- Analog input voltage ≤ voltage tap : bit 8 = 0
- <7> In this way, all the bits of SAR, including bit 0, are compared.

<8> When all the 10 bits of SAR have been compared, SAR holds the valid digital result whose values are transferred and latched to the A/D conversion result register (ADCR0).

At the same time, an A/D conversion end interrupt request (INTAD0) can be generated.

#### 🗰 6427525 0099607 4T7 🛲

# Figure 11-4. Basic Operation of A/D Converter

|                               | Conversion              |                          |
|-------------------------------|-------------------------|--------------------------|
|                               | Sampling time           |                          |
| Operation of<br>A/D converter | Sampling A/D conversion |                          |
| SAR                           | Un-<br>defined          | Conversion<br>Conversion |
| ADCR0                         |                         | Conversion<br>result     |
| INTADO                        |                         |                          |

The A/D conversion is performed continuously, until the bit 7 of ADM0 (ADCS0) is reset to 0 by software. If the data of the ADM0 register or ADS0 register is rewritten during the A/D conversion, the conversion is initialized. If the ADCS0 bit is set to 1 at this time, conversion is performed again from the start.

The contents of the ADCR0 register become undefined when the  $\overrightarrow{\text{RESET}}$  signal is input.

# 11.4.2 Input voltage and conversion result

The relation between the analog voltage input to the analog input pins (ANI0 to ANI7) and A/D conversion result (value stored to A/D conversion result register (ADCR0)) is as follows:

$$ADCR0 = INT \left(\frac{V_{IN}}{AV_{REF}} \times 1024 + 0.5\right)$$

or,

$$(ADCR0 - 0.5) \times \frac{AV_{REF}}{1024} \le V_{IN} < (ADCR0 + 0.5) \times \frac{AV_{REF}}{1024}$$

Remark INT() : function returning integer of value in ()

VIN : analog input voltage AVREF : AVREF pin voltage ADCR0: value of A/D conversion result register (ADCR0)

- , ,

Figure 11-5 shows the relations between the analog input voltage and A/D conversion result.

Figure 11-5. Relations between Analog Input Voltage and A/D Conversion Result



#### 11.4.3 Operation mode of A/D converter

The A/D converter operates in the select mode only. One analog input channel is selected from ANI0 to ANI7 for A/D conversion by using the analog input channel specification register 0 (ADS0).

The A/D conversion can be started in the following two ways:

- Hardware start : Conversion is started by trigger input (P03).
- Software start : Conversion is started by setting ADM0.

The result of the A/D conversion is stored in the A/D conversion result register (ADCR0), and at the same time, an interrupt request signal (INTAD0) is generated.

#### (1) A/D conversion operation by hardware start

The A/D conversion stands by when both bits 6 (TRG0) and 7 (ADCS0) of A/D converter mode register (ADM0) are set to 1. When an external trigger signal (P03) is input, the voltage applied to the analog input pin specified by ADS0 is converted into a digital value.

When the A/D conversion has been completed, the result of the conversion is stored in the A/D conversion result register (ADCR0), and an interrupt request signal (INTAD0) is generated. Once the A/D conversion has been started and when one A/D conversion has been completed, the next A/D conversion is not started unless a new external trigger signal is input.

If data whose ADCS0 is 1 is written again to ADM0 during A/D conversion, the AD conversion under execution is stopped, and stands by until a new external trigger signal is input. When the external trigger signal is input, A/D conversion is performed again from the start.

When 0 is written to the ADCS0 bit of ADM0 during A/D conversion, the conversion is immediately stopped.



🔳 6427525 0099610 T91 📟

Figure 11-6. A/D Conversion by Hardware Start (When falling edge is specified)

# (2) A/D conversion by software start

By setting bit 6 (TRG0) of the A/D converter mode register (ADM0) to 0 and setting bit 7 (ADCS0) to 1, the voltage applied to the analog input pin specified by ADS0 is converted into digital values.

When the A/D conversion has been completed, the result of the conversion is stored in the A/D conversion result register (ADCR0), and an interrupt request signal (INTAD0) is generated. When the A/D conversion has been started once, and one A/D conversion has been completed, the next A/D conversion is immediately started. In this way, A/D conversion is repeatedly executed until new data is written to ADM0.

If data whose ADCS0 is 1 is written again to ADM0 during A/D conversion, the conversion under execution is stopped, and the A/D conversion of the newly written data is started.

If data whose ADCS0 is 0 is written to ADM0 during A/D conversion, the conversion is immediately stopped.



Figure 11-7. A/D Conversion by Software Start

Remark n = 0, 1, ..., 7 m = 0, 1, ..., 7

#### 11.5 Notes on A/D Converter

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

The A/D converter stops operating in the standby mode. At this time, the current consumption can be reduced by stopping the conversion operation (by clearing bit 7 (ADCS0) of the A/D converter mode register 0 (ADM0) to 0). An example of reducing the current consumption in standby mode is shown in Figure 11-8.

Figure 11-8. Example of Reducing Current Consumption in Standby Mode



#### (2) ANIO to ANI7 input range

Observe the rated range of the ANI0 to ANI7 input voltage. If a voltage of AVREF or higher, or AVss or lower (even in the range of absolute maximum ratings) is input to an analog input channel, the converted value of that channel becomes undefined. In addition, the converted values of the other channels may also be affected.

- (3) Conflicting operations
  - <1> Conflict between writing A/D conversion result register (ADCR0) on completion of conversion and reading ADCR0 by instruction

Reading ADCR0 takes precedence. After it has been read, a new conversion result is written to ADCR0.

- <2> Conflict between writing ADCR0 on completion of conversion and external trigger signal input The external trigger signal is not accepted during A/D conversion. Therefore, the external trigger signal is not accepted while ADCR0 is written.
- <3> Conflict between writing ADCR0 on completion of conversion and writing A/D converter mode register 0 (ADM0) or writing analog input channel specification register 0 (ADS0) Writing ADM0 or ADS0 takes precedence. ADCR0 is not written. The conversion end interrupt request signal (INTAD0) is not generated.

152

■ 6427525 0099612 864 **■** 

# (4) Countermeasures against noise

To keep the resolution of 10 bits, noise superimposed on the AVREF and ANI0 to ANI7 pins must be suppressed as much as possible. The higher the output impedance of the analog input source, the greater the effect. To suppress noise, connecting an external capacitor as shown in Figure 11-9 is recommended.





# (5) ANI0/P10 to ANI7/P17

The analog input pins (ANI0 to ANI7) are also used as input port pins (PORT 1). When A/D conversion is performed with any of ANI0 to ANI7 selected, do not execute the input instruction of PORT 1 while conversion is in progress; otherwise, the conversion resolution may be degraded. If a digital pulse is applied to the pins adjacent to the pins currently used for A/D conversion, the expected value of the A/D conversion may not be obtained due to coupling noise. Therefore, do not apply a pulse to the adjacent pins to the pin under A/D conversion.

# (6) Input impedance to AVREF pin

A series resistor string of about 47  $k\Omega$  is connected between the AVREF and AVss pins.

If the output impedance of the reference voltage source is high, therefore, an error of the reference voltage increases by connecting the impedance in parallel with the series resistor string between the AVREF and AVss pins.

# (7) Interrupt request flag (ADIF)

The interrupt request flag (ADIF) is not cleared even when the contents of the A/D converter mode register 0 (ADM0) are changed.

When the analog input pin is changed during A/D conversion, therefore, the chances are that the A/D conversion result of the old analog input and interrupt request flags are set immediately before the contents of ADMO are rewritten. Consequently, ADIF may be set even if A/D conversion for the newly specified analog input pin has not yet been completed when ADIF is read immediately after ADMO has been rewritten (refer to Figure 11-10).

To resume A/D conversion that has been once stopped, clear ADIF before resuming the conversion.





Remark n = 0, 1, ..., 7 n = 0, 1, ..., 7

(8) AVoo pin

154

The AVod pin is the power supply pin to the analog circuit and supplies power to the input circuit of ANI0/P10 to ANI7/P17.

Therefore, even in the application which can be switched over to backup power source, be sure to apply the same voltage as Voto as shown in Figure 11-11.



Figure 11-11. Processing of AVDD Pin

# **CHAPTER 12 SERIAL INTERFACE**

# 12.1 Serial Interface Functions

Serial interface has the following three modes.

- · Operation stop mode
- · Asynchronous serial interface (UART) mode
- Infrared data transfer (IrDA) mode (UART00 only)

# (1) Operation stop mode

This mode is used when serial transfer is not carried out to reduce power consumption.

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

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

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

The MIDI standard baud rate (31.25 kbps) can be used by employing the dedicated UART baud rate generator.

(3) Infrared data transfer (IrDA) mode

# 6427525 00996<u>1</u>5 573 🔜

# 12.2 Serial Interface Configuration

Serial interface consists of the following hardware.

| Table 12-1. Serial Interface Configuration | Table | 12-1. | Serial | Interface | Configuration |
|--------------------------------------------|-------|-------|--------|-----------|---------------|
|--------------------------------------------|-------|-------|--------|-----------|---------------|

| Item             | Configuration                                                                                                                                                                              |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register         | Transmit shift registers (TXS00, TXS01)                                                                                                                                                    |
|                  | Receive shift registers (RX00, RX01)                                                                                                                                                       |
|                  | Receive buffer registers (RXB00, RXB01)                                                                                                                                                    |
| Control register | Asynchronous serial interface mode registers (ASIM00, ASIM01)<br>Asynchronous serial interface status registers (ASIS00, ASIS01)<br>Baud rate generator control registers (BRGC00, BRGC01) |

## Figure 12-1. Serial Interface (UART00) Block Diagram





Powered by ICminer.com Electronic-Library Service CopyRight 2003

\_\_\_\_\_



Figure 12-2. Serial Interface (UART01) Block Diagram

# (1) Transmit shift register (TXS0n)

This register is used to set the transmit data. The data written in TXSOn is transmitted as serial data. If the data length is specified as 7 bits, bits 0 to 6 of the data written in TXSOn are transferred as transmit data. Writing data to TXSOn starts the transmit operation.

TXSOn is written to with an 8-bit memory manipulation instruction. It cannot be read. TXSOn value is FFH after RESET input.

# Caution TXS0n must not be written to during a transmit operation. TXS0n and the receive buffer register (RXB0n) are allocated to the same address, and when a read is performed, the value of RXB0n is read.

### (2) Receive shift register (RX0n)

This register is used to convert serial data input to the RxD0n pin to parallel data. When one byte of data is received, the receive data is transferred to the receive buffer register (RXB0n). RXS0n cannot be directly manipulated by a program.

# (3) Receive buffer register (RXB0n)

This register holds receive data. Each time one byte of data is received, new receive data is transferred from the receive shift register (RXS0n).

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

RXB0n is read with an 8-bit memory manipulation instruction. It cannot be written to. RXB0n value is FFH after RESET input.

# Caution RXB0n and the transmit shift register (TXS0n) are allocated to the same address, and when a write is performed, the value is written to TXS0n.

### (4) Transmission control circuit

This circuit performs transmit operation control such as the addition of a start bit, parity bit and stop bit to data written in the transmit shift register (TXS0n) in accordance with the contents set in the asynchronous serial interface mode register (ASIM0n).

### (5) Reception control circuit

This circuit controls receive operations in accordance with the contents set in the asynchronous serial interface mode register (ASIM0n). It performs error checks for parity errors, etc., during a receive operation, and if an error is detected, sets a value in the asynchronous serial interface status register (ASIS0n) in accordance with the error contents.

Remark n = 0, 1

158

**6**427525 0099618 282 **1** 

### 12.3 Registers Controlling Serial Interface

The following six registers control the serial interface.

- Asynchronous serial interface mode registers (ASIM00, ASIM01)
- Asynchronous serial interface status registers (ASIS00, ASIS01)
- Baud rate generator control registers (BRGC00, BRGC01)

# (1) Asynchronous serial interface mode registers (ASIM00, ASIM01)

ASIM00 and ASIM01 are 8-bit registers that control the serial transmit operation of the asynchronous serial interface.

These registers are set by a 1-bit or 8-bit memory manipulation instruction. When the  $\overrightarrow{\text{RESET}}$  signal is input, these registers are set to 00H.

# Figure 12-3. Format of Asynchronous Serial Interface Mode Register 0

|        | $\sim$ | $\sim$ |       |       |      |      |        |         | Address | On reset | R/W |
|--------|--------|--------|-------|-------|------|------|--------|---------|---------|----------|-----|
| ASIM00 | TXE00  | RXE00  | PS001 | PS000 | CL00 | SL00 | ISRM00 | IRDAM00 | FFA0H   | 00H      | R/W |

| TXE00 | RXE00 | Operating Mode                        | Function of<br>RxD00/P20 pin | Function of<br>TxD00/P21 pin |
|-------|-------|---------------------------------------|------------------------------|------------------------------|
| 0     | 0     | Stop operation                        | Port function                | Port function                |
| 0     | 1     | UART mode<br>(reception only)         | Serial function              | Port function                |
| 1     | 0     | UART mode<br>(transmission only)      | Port function                | Serial function              |
| 1     | 1     | UART mode<br>(transmission/reception) | Serial function              | Serial function              |

| PS001 | PS000 | Parity Bit Specification                                                                               |
|-------|-------|--------------------------------------------------------------------------------------------------------|
| 0     | 0     | No parity                                                                                              |
| 0     | 1     | Transmission = Always 0 parity addition<br>Reception = Parity not checked (parity error not generated) |
| 1     | 0     | Odd parity                                                                                             |
| 1     | 1     | Even parity                                                                                            |

| CL00 | Character Length Specification |
|------|--------------------------------|
| 0    | 7 bits                         |
| 1    | 8 bits                         |

| SL00 | Transmit Data Stop Bit Length Specification |
|------|---------------------------------------------|
| 0    | 1 bit                                       |
| 1    | 2 bits                                      |

| ISRMOO | Controls Reception End Interrupt on Occurrence of Error.          |
|--------|-------------------------------------------------------------------|
| 0      | Generates reception end interrupt on occurrence of error.         |
| 1      | Does not generate reception end interrupt on occurrence of error. |

| IRDAM00 | Specifies Operation of IrDA Mode <sup>Note1</sup> . |
|---------|-----------------------------------------------------|
| 0       | UART (transmission/reception) mode                  |
| 1       | IrDA (transmission/reception) mode <sup>Note2</sup> |

Notes 1. The UART or IrDA mode is specified by TXE00 and RXE00.

2. When using the IrDA mode, be sure to clear bits 3 to 0 (MLD003 to MLD000) of the baud rate generator control register (BRGC00) to 0000 (set the clock to fsck/16).

Caution Before changing the operating mode, be sure to stop the serial transmission/reception.

160

🗖 6427525 0099620 930 📰

Figure 12-4. Format of Asynchronous Serial Interface Mode Register 1

|        |       |       |       |       |      |      |        |   | Address |     |     |
|--------|-------|-------|-------|-------|------|------|--------|---|---------|-----|-----|
| ASIM01 | TXE01 | RXE01 | PS011 | PS010 | CL01 | SL01 | ISRM01 | 0 | FFA4H   | 00H | R/W |

| TXE01 | RXE01 | Operating Mode                        | Function of<br>RxD01/P22 pin | Function of<br>TxD01/P23 pin |
|-------|-------|---------------------------------------|------------------------------|------------------------------|
| 0     | 0     | Stop operation                        | Port function                | Port function                |
| 0     | 1     | UART mode<br>(reception only)         | Serial function              | Port function                |
| 1     | 0     | UART mode<br>(transmission only)      | Port function                | Serial function              |
| 1     | 1     | UART mode<br>(transmission/reception) | Serial function              | Serial function              |

| PS011 | PS010 | Parity Bit Specification                                                                               |
|-------|-------|--------------------------------------------------------------------------------------------------------|
| 0     | 0     | No parity                                                                                              |
| 0     | 1     | Transmission = Always 0 parity addition<br>Reception = Parity not checked (parity error not generated) |
| 1     | 0     | Odd parity                                                                                             |
| 1     | 1     | Even parity                                                                                            |

| CL01 | Character Length Specification |
|------|--------------------------------|
| 0    | 7 bits                         |
| 1    | 8 bits                         |

| SL01 | Transmit Data Stop Bit Length Specification |
|------|---------------------------------------------|
| 0    | 1 bit                                       |
| 1    | 2 bits                                      |

| ISRM01 | Controls Reception End Interrupt on Occurrence of Error.          |
|--------|-------------------------------------------------------------------|
| 0      | Generates reception end interrupt on occurrence of error.         |
| 1      | Does not generate reception end interrupt on occurrence of error. |

Caution Before changing the operating mode, be sure to stop the serial transmission/reception.

\_\_·

(2) Asynchronous serial interface status registers (ASIS00, ASIS01)

ASIS00 and ASIS01 are the registers that indicate the error contents when a receive error occurs. These registers can be read by an 8-bit memory manipulation instruction. When the RESET signal is input, these registers are set to 00H.



Symbol Address R/W 7 6 5 4 3 2 1 0 On reset ASIS00 0 PE00 FE00 OVE00 FFA1H 00H R n 0 0 0 PE00 Parity Error Flag 0 Parity error does not occur. 1 Parity error occurs (transmit data parity specification and receive data parity do not match). FE00 Framing Error Flag 0 Framing error does not occur. Framing error occurs<sup>Note1</sup>. 1 (stop bit not detected) OVE00 **Overrun Error Flag** 0 Overrun error does not occur. Overrun error occurs<sup>Note2</sup> (Next receive comple-1

ted before data is read from receive buffer).

Notes 1. Even if the stop bit length is set to 2 bits by using bit 2 (SL00) of the asynchronous serial interface mode register (ASIM00), only 1 stop bit is detected during reception.

6427525 0099622 703 📖

2. If an overrun error occurs, be sure to read the receive buffer register (RXB00). Until RXB00 is read, an overrun error persistently occurs each time data has been received.

Powered by ICminer.com Electronic-Library Service CopyRight 2003

Figure 12-6. Format of Asynchronous Serial Interface Status Register 1

| Symbol | 7     | 6                      | 5        | 4                    | 3       | 2                    | 1    | 0     | Address | On reset | R/W |
|--------|-------|------------------------|----------|----------------------|---------|----------------------|------|-------|---------|----------|-----|
| ASIS01 | 0     | 0                      | 0        | 0                    | o       | PE01                 | FE01 | OVE01 | FFA5H   | 00H      | R   |
|        |       |                        |          |                      |         |                      |      |       |         |          |     |
|        | PE01  | Parity                 | Error    | Flag                 |         |                      |      |       |         |          |     |
|        | 0     | Parity                 | error o  | does no              | t occur | •                    |      |       |         |          |     |
|        | 1     |                        |          | occurs (<br>aceive c |         |                      |      |       |         |          |     |
|        |       |                        |          |                      |         |                      |      |       |         |          |     |
|        | FE01  | Fram                   | ing Err  | or Flag              |         |                      |      |       |         |          |     |
|        | 0     | Fram                   | ing err  | or does              | not oc  | cur.                 |      |       |         |          |     |
|        | 1     |                        |          | or occui<br>detecte  |         |                      |      |       |         |          |     |
|        |       |                        |          |                      |         |                      |      |       |         |          |     |
|        | OVE01 | E01 Overrun Error Flag |          |                      |         |                      |      |       |         |          |     |
|        | 0     | Over                   | run erro | or does              | not occ |                      |      |       |         |          |     |
|        | 1     |                        |          |                      |         | Next ree<br>n receiv |      |       |         |          |     |

- Notes 1. Even if the stop bit length is set to 2 bits by using bit 2 (SL01) of the asynchronous serial interface mode register (ASIM01), only 1 stop bit is detected during reception.
  - 2. If an overrun error occurs, be sure to read the receive buffer register (RXB01). Until RXB01 is read, an overrun error persistently occurs each time data has been received.

163

# (3) Baud rate generator control registers (BRGC00, BRGC01)

BRGC00 and BRGC01 are the registers that set the serial clock of the asynchronous serial interface. These registers are set by an 8-bit memory manipulation instruction. When the RESET signal is input, these registers are set to 00H.

6427525 0099623 64T 🖿

Powered by ICminer.com Electronic-Library Service CopyRight 2003

# Figure 12-7. Format of Baud Rate Generator Control Register 0

|        |   |        |        |        |        |        |        |        |       | On reset |     |
|--------|---|--------|--------|--------|--------|--------|--------|--------|-------|----------|-----|
| BRGC00 | 0 | TPS002 | TPS001 | TPS000 | MDL003 | MDL002 | MDL001 | MDL000 | FFA2H | 00H      | R/W |

| TPS001 | TPS000                | 5-Bit Counter Source Clock Selection                                                                |
|--------|-----------------------|-----------------------------------------------------------------------------------------------------|
| 0      | 0                     | fx/2 (4.19 MHz)                                                                                     |
| 0      | 1                     | fx/2 <sup>2</sup> (2.1 MHz)                                                                         |
| 1      | 0                     | fx/2 <sup>3</sup> (1.05 MHz)                                                                        |
| 1      | 1                     | fx/2 <sup>4</sup> (524 kHz)                                                                         |
| 0      | 0                     | fx/2 <sup>5</sup> (262 kHz)                                                                         |
| 0      | 1                     | fx/2 <sup>6</sup> (131 kHz)                                                                         |
| 1      | 0                     | fx/2 <sup>7</sup> (65.5 kHz)                                                                        |
| 1      | 1                     | fx/2 <sup>8</sup> (32.7 kHz)                                                                        |
|        | 0<br>0<br>1<br>1<br>0 | 0         1           1         0           1         1           0         0           0         1 |

| MDL003 | MDL002 | MDL001 | MDL000 | Baud Rate Generator<br>Input Clock Selection | k  |
|--------|--------|--------|--------|----------------------------------------------|----|
| 0      | 0      | 0      | 0      | fsck/16                                      | 0  |
| 0      | 0      | 0      | 1      | fsck/17                                      | 1  |
| 0      | 0      | 1      | 0      | fscк/18                                      | 2  |
| 0      | 0      | 1      | 1      | fsck/19                                      | 3  |
| 0      | 1      | D      | 0      | fscx/20                                      | 4  |
| 0      | 1      | 0      | 1      | fscx/21                                      | 5  |
| 0      | 1      | 1      | 0      | fscx/22                                      | 6  |
| 0      | 1      | 1      | 1      | fsck/23                                      | 7  |
| 1      | 0      | 0      | 0      | fsck/24                                      | 8  |
| 1      | 0      | 0      | 1      | fsck/25                                      | 9  |
| 1      | 0      | 1      | 0      | fsck/26                                      | 10 |
| 1      | 0      | 1      | 1      | fscx/27                                      | 11 |
| 1      | 1      | 0      | 0      | fscx/28                                      | 12 |
| 1      | 1      | 0      | 1      | fsck/29                                      | 13 |
| 1      | 1      | 1      | 0      | fsck/30                                      | 14 |
| 1      | 1      | 1      | 1      | Setting prohibited                           | -  |

Caution If a write to the BRGC00 is performed during communication, the output of baud rate generator may be disrupted, preventing normal communication from continuing. The BRGC00 should therefore not be written to during communication.

🖬 6427525 0099624 586 🔳

**Remarks 1.** (): at fx = 8.38-MHz operation

- 2. fsck: 5-bit counter source clock
- 3. k: Value set in bits MDL000 to MDL003 ( $0 \le k \le 14$ )

164

Powered by ICminer.com Electronic-Library Service CopyRight 2003

### Figure 12-8. Format of Baud Rate Generator Control Register 1

|        |   |        |        |        |        |        |        |        | Address |     |     |
|--------|---|--------|--------|--------|--------|--------|--------|--------|---------|-----|-----|
| BRGC01 | 0 | TPS012 | TPS011 | TPS010 | MDL013 | MDL012 | MDL011 | MDL010 | FFA6H   | 00H | R/W |

| TPS012 | TPS011 | TPS010 | 5-Bit Counter Source Clock Selection |
|--------|--------|--------|--------------------------------------|
| 0      | 0      | 0      | fz/2 <sup>4</sup> (524 kHz)          |
| 0      | 0      | 1      | fx/2⁵ (262 kHz)                      |
| 0      | 1      | 0      | fx/2 <sup>6</sup> (131 kHz)          |
| 0      | 1      | 1      | fx/2 <sup>7</sup> (65.5 kHz)         |
| 1      | 0      | 0      | fx/2 <sup>8</sup> (32.7 kHz)         |
| 1      | 0      | 1      | fx/2 <sup>9</sup> (16.4 kHz)         |
| 1      | 1      | 0      | fx/2 <sup>10</sup> (8.2 kHz)         |
| 1      | 1      | 1      | fx/2 <sup>11</sup> (4.1 kHz)         |

| MDL013 | MDL012 | MDL011 | MDL010 | Baud Rate Generator<br>Input Clock Selection |    |
|--------|--------|--------|--------|----------------------------------------------|----|
| 0      | 0      | 0      | 0      | fsck/16                                      | 0  |
| 0      | 0      | 0      | 1      | fscк/17                                      | 1  |
| 0      | 0      | 1      | 0      | fsck/18                                      | 2  |
| 0      | 0      | 1      | 1      | fscx/19                                      | З  |
| 0      | 1      | 0      | 0      | fscx/20                                      | 4  |
| 0      | 1      | 0      | 1      | fsck/21                                      | 5  |
| 0      | 1      | 1      | 0      | tsck/22                                      | 6  |
| 0      | 1      | 1      | 1      | fsck/23                                      | 7  |
| 1      | 0      | 0      | 0      | fscx/24                                      | 8  |
| 1      | 0      | 0      | 1      | fscx/25                                      | 9  |
| 1      | 0      | 1      | 0      | fscx/26                                      | 10 |
| 1      | 0      | 1      | 1      | fscx/27                                      | 11 |
| 1      | 1      | 0      | 0      | fsck/28                                      | 12 |
| 1      | 1      | 0      | 1      | fscк/29                                      | 13 |
| 1      | 1      | 1      | 0      | fscx/30                                      | 14 |
| 1      | 1      | 1      | 1      | Setting prohibited                           | -  |

Caution If a write to the BRGC01 is performed during communication, the output of baud rate generator may be disrupted, preventing normal communication from continuing. The BRGC01 should therefore not be written to during communication.

**Remarks 1.** (): at fx = 8.38-MHz operation

- 2. fsck: 5-bit counter source clock
- 3. k: Value set in bits MDL010 to MDL013 ( $0 \le k \le 14$ )

🛚 6427525 0099625 412 🛤

### 12.4 Operation of Serial Interface

The following three operating modes are available to the serial interface.

- Operation stop mode
- · Asynchronous serial interface (UART) mode
- Infrared data transfer (IrDA) mode (UART00 only)

### 12.4.1 Operation stop mode

Serial transfer is not executed in this mode. Consequently, the power dissipation can be reduced. In the operation stop mode, the pins can be used as ordinary port pins.

### (1) Register setting

The operation stop mode is set by using the asynchronous serial interface mode register (ASIM00, ASIM01). ASIM00 and ASIM01 are set by using a 1-bit or 8-bit memory manipulation instruction. These registers are set to 00H when the RESET signal is input.

Symbol ര (6) 5 З 2 1 0 Address R/W 4 On reset ASIM0n TXEOn RXEOn PSOn1 PSOn0 CLOn SL0n FFA0H, **00H** R/W ISRMON IRDAMO FFA4H

| TXE0n | RXE0n | Operating Mode                        | Function of RxD00/P20,<br>RxD01/P22 pins | Function of TxD00/P21,<br>TxD01/P23 pins |
|-------|-------|---------------------------------------|------------------------------------------|------------------------------------------|
| 0     | 0     | Stop operation                        | Port function                            | Port function                            |
| 0     | 1     | UART mode<br>(reception only)         | Serial function                          | Port function                            |
| 1     | 0     | UART mode<br>(transmission only)      | Port function                            | Serial function                          |
| 1     | 1     | UART mode<br>(transmission/reception) | Serial function                          | Serial function                          |

Caution Before changing the operating mode, be sure to stop the serial transmission/reception.

Remark n = 0, 1

## 12.4.2 Asynchronous serial interface (UART) mode

In this mode, one byte of data is transmitted/received following a start bit, and full-duplex operation is possible. A baud rate generator is incorporated, enabling communication to be performed at any of a wide range of baud

### rates.

The baud rate (31.25 kbps) conforming to the MIDI standard can be used by using the UART-dedicated baud rate generator.

#### (1) Register setting

The UART mode is set by using the asynchronous serial interface mode registers (ASIM00 and ASIM01), asynchronous serial interface status registers (ASIS00 and ASIS01), and baud rate generator control registers (BRGC00 and BRGC01).



# (a) Asynchronous serial interface mode registers (ASIM00, ASIM01)

AS1M00 and AS1M01 are set by a 1-bit or 8-bit memory manipulation instruction. These registers are set to 00H when the  $\overrightarrow{\mathsf{RESET}}$  signal is input.

| Symbol | 7     | 6     | 5     | 4     | 3    | 2    | 1      | 0       | Address | On reset | R/W |
|--------|-------|-------|-------|-------|------|------|--------|---------|---------|----------|-----|
| ASIM00 | TXE00 | RXE00 | PS001 | PS000 | CL00 | SL00 | ISRM00 | IRDAM00 | FFA0H   | 00H      | R/W |

| TXE00 | RXE00 | Operating Mode                        | Function of<br>RxD00/P20 pin | Function of<br>TxD00/P21 pin |
|-------|-------|---------------------------------------|------------------------------|------------------------------|
| 0     | 0     | Stop operation                        | Port function                | Port function                |
| 0     | 1     | UART mode<br>(reception only)         | Serial function              | Port function                |
| 1     | 0     | UART mode<br>(transmission only)      | Port function                | Serial function              |
| 1     | 1     | UART mode<br>(transmission/reception) | Serial function              | Serial function              |

| PS001 | PS000 | Parity Bit Specification                                                                               |
|-------|-------|--------------------------------------------------------------------------------------------------------|
| 0     | 0     | No parity                                                                                              |
| 0     | 1     | Transmission = Always 0 parity addition<br>Reception = Parity not checked (parity error not generated) |
| 1     | 0     | Odd parity                                                                                             |
| 1     | 1     | Even parity                                                                                            |

| CL00 | Character Length Specification |
|------|--------------------------------|
| 0    | 7 bits                         |
| 1    | 8 bits                         |

| SL00 | Transmit Data Stop Bit Length Specification |
|------|---------------------------------------------|
| 0    | 1 bit                                       |
| 1    | 2 bits                                      |

| ISRMOO | Controls Reception End Interrupt on Occurrence of Error.          |  |  |
|--------|-------------------------------------------------------------------|--|--|
| 0      | Generates reception end interrupt on occurrence of error.         |  |  |
| 1      | Does not generate reception end interrupt on occurrence of error. |  |  |

| IRDAM00 | Specifies Operation of IrDA Mode <sup>Note1</sup> . |
|---------|-----------------------------------------------------|
| 0       | UART (transmission/reception) mode                  |
| 1       | IrDA (transmission/reception) mode <sup>Note2</sup> |

Notes 1. The UART or IrDA mode is specified by TXE00 and RXE00.

 When using the IrDA mode, be sure to clear bits 3 to 0 (MLD003 to MLD000) of the baud rate generator control register (BRGC00) to 0000 (set the clock to fsck/16).

🔲 6427525 0099627 295 🎟

|        | <u> </u> | <u> </u> |       |       |      |      |        |   | Address |     |     |
|--------|----------|----------|-------|-------|------|------|--------|---|---------|-----|-----|
| ASIM01 | TXE01    | RXE01    | PS011 | PS010 | CL01 | SL01 | ISRM01 | 0 | FFA4H   | 00H | R/W |

| TXE01 | RXE01 | Operating Mode                        | Function of<br>RxD01/P22 pin | Function of<br>TxD01/P23 pin |
|-------|-------|---------------------------------------|------------------------------|------------------------------|
| 0     | 0     | Stop operation                        | Port function                | Port function                |
| 0     | 1     | UART mode<br>(reception only)         | Serial function              | Port function                |
| 1     | 0     | UART mode<br>(transmission only)      | Port function                | Serial function              |
| 1     | 1     | UART mode<br>(transmission/reception) | Serial function              | Serial function              |

| PS011 | PS010 | Parity Bit Specification                                                                               |
|-------|-------|--------------------------------------------------------------------------------------------------------|
| 0     | 0     | No parity                                                                                              |
| 0     | 1     | Transmission = Always 0 parity addition<br>Reception = Parity not checked (parity error not generated) |
| 1     | 0     | Odd parity                                                                                             |
| 1     | 1     | Even parity                                                                                            |

| CL01 | Character Length Specification |
|------|--------------------------------|
| 0    | 7 bits                         |
| 1    | 8 bits                         |

| SL01 | Transmit Data Stop Bit Length Specification |
|------|---------------------------------------------|
| 0    | 1 bit                                       |
| 1    | 2 bits                                      |

| ISRM01 | Controls Reception End Interrupt on Occurrence of Error.          |
|--------|-------------------------------------------------------------------|
| 0      | Generates reception end interrupt on occurrence of error.         |
| 1      | Does not generate reception end interrupt on occurrence of error. |

Caution Before changing the operating mode, be sure to stop the serial transmission/reception.

168

🖬 6427525 0099628 121 페

Powered by ICminer.com Electronic-Library Service CopyRight 2003

(b) Asynchronous serial interface status registers (ASIS00, ASIS01) ASIS00 and ASIS01 can be read by an 8-bit memory manipulation instruction. When the RESET signal is input, these registers are set to 00H.

| Symbol | 7       | 6      | 5                                                                  | 4       | 3                    | 2                      | 1        | 0      | Address         | On reset | R/W |
|--------|---------|--------|--------------------------------------------------------------------|---------|----------------------|------------------------|----------|--------|-----------------|----------|-----|
| ASIS0n | 0       | 0      | 0                                                                  | 0       | 0                    | PE0n                   | FE0n     | OVE0n  | FFA1H,<br>FFA5H | 00H      | R   |
|        |         |        |                                                                    | 1       |                      |                        |          |        | FFASH           |          |     |
|        | PE0n    | Parity | / Error l                                                          | Flag    |                      |                        |          |        |                 |          |     |
|        | 0       | Parity | error o                                                            | loes no | t occur.             | •                      |          |        |                 |          |     |
|        | 1       | -      |                                                                    |         |                      | it data p<br>rity do n |          | 1      |                 |          |     |
| I      | <b></b> |        |                                                                    |         |                      |                        |          |        |                 |          |     |
|        | FE0n    | Fram   | Framing Error Flag                                                 |         |                      |                        |          |        |                 |          |     |
|        | 0       | Fram   | ing erro                                                           | or does | not occ              | cur.                   |          |        |                 |          |     |
|        | 1       |        | Framing error occurs <sup>Note1</sup> .<br>(stop bit not detected) |         |                      |                        |          |        |                 |          |     |
|        |         |        |                                                                    |         |                      |                        |          |        |                 |          |     |
|        | OVE0n   | Over   | run Erre                                                           | or Flag |                      |                        |          |        |                 |          |     |
|        | 0       | Over   | run erro                                                           | or does | not occ              | cur.                   |          |        |                 |          |     |
|        | 1       | Over   | run erro                                                           |         | S <sup>Note2</sup> ( | Next rea               | ceive co | omple- |                 |          |     |

ted before data is read from receive buffer).

- Notes 1. Even if the stop bit length is set to 2 bits by using bit 2 (SL0n) of the asynchronous serial interface mode register (ASIM0n), only 1 stop bit is detected during reception.
  - 2. If an overrun error occurs, be sure to read the receive buffer register (RXB0n). Until RXB0n is read, an overrun error persistently occurs each time data has been received.

Remark n = 0, 1

6427525 0099629 068 🔳

(c) Baud rate generator control registers (BRGC00, BRGC01) BRGC00 and BRGC01 are set by an 8-bit memory manipulation instruction. These registers are set to 00H when the RESET signal is input.

| -      |   | •      | -      | •      | -      |        |        |        | Address |             |     |
|--------|---|--------|--------|--------|--------|--------|--------|--------|---------|-------------|-----|
| BRGC00 | 0 | TPS002 | TPS001 | TPS000 | MDL003 | MDL002 | MDL001 | MDL000 | FFA2H   | <b>00</b> H | R/W |

|        |        | -      | 5-Bit Counter Source Clock Selection |
|--------|--------|--------|--------------------------------------|
| TPS002 | TPS001 | TPS000 | 5-Bit Counter Source Clock Selection |
| 0      | 0      | 0      | fx/2 (4.19 MHz)                      |
| 0      | 0      | 1      | fx/2 <sup>2</sup> (2.1 MHz)          |
| 0      | 1      | 0      | fx/2 <sup>3</sup> (1.05 MHz)         |
| 0      | 1      | 1      | fx/2 <sup>4</sup> (524 kHz)          |
| 1      | 0      | 0      | fx/2 <sup>5</sup> (262 kHz)          |
| 1      | 0      | 1      | fx/2 <sup>5</sup> (131 kHz)          |
| 1      | 1      | 0      | fx/2 <sup>7</sup> (65.5 kHz)         |
| 1      | 1      | 1      | fx/2 <sup>8</sup> (32.7 kHz)         |

| MDL003 | MDL002 | MDL001 | MDL000 | Baud Rate Generator<br>Input Clock Selection |    |
|--------|--------|--------|--------|----------------------------------------------|----|
| 0      | 0      | 0      | 0      | fsck/16                                      | 0  |
| 0      | 0      | 0      | 1      | fsck/17                                      | 1  |
| 0      | 0      | 1      | 0      | fsck/18                                      | 2  |
| 0      | 0      | 1      | 1      | fscx/19                                      | 3  |
| 0      | 1      | 0      | 0      | fscx/20                                      | 4  |
| 0      | 1      | 0      | 1      | fsck/21                                      | 5  |
| 0      | 1      | 1      | 0      | tsck/22                                      | 6  |
| 0      | 1      | 1      | 1      | fscx/23                                      | 7  |
| 1      | 0      | 0      | 0      | fscx/24                                      | 8  |
| 1      | 0      | 0      | 1      | fsck/25                                      | 9  |
| 1      | 0      | 1      | 0      | fsck/26                                      | 10 |
| 1      | 0      | 1      | 1      | fscx/27                                      | 11 |
| 1      | 1      | 0      | 0      | fscx/28                                      | 12 |
| 1      | 1      | 0      | 1      | tscx/29                                      | 13 |
| 1      | 1      | 1      | 0      | fsck/30                                      | 14 |
| 1      | 1      | 1      | 1      | Setting prohibited                           | -  |

Caution If a write to the BRGC00 is performed during communication, the output of baud rate generator may be disrupted, preventing normal communication from continuing. The BRGC00 should therefore not be written to during communication.

🖬 6427525 0099630 88T 🏬

**Remarks 1.** ( ): at fx = 8.38-MHz operation

- 2. fsck: 5-bit counter source clock
- 3. k: Value set in bits MDL000 to MDL003 ( $0 \le k \le 14$ )

| Symbol | 7      | 6      | 5        | 4                 | 3        | 2        | 1        | 0        | Address | On reset | R/W |
|--------|--------|--------|----------|-------------------|----------|----------|----------|----------|---------|----------|-----|
| BRGC01 | 0      | TPS012 | TPS011 T | PS010             | MDL013   | MDL012   | MDL011   | MDL010   | FFA6H   | 00H      | R/W |
|        |        | 1      |          |                   | ·        |          |          |          |         |          |     |
|        | TPS012 | TPS011 | TPS010   | 5-Bit             | Counte   | r Source | Clock Se | election |         |          |     |
|        | 0      | 0      | 0        | fx/2 <sup>4</sup> | (524 k   | Hz)      |          |          |         |          |     |
|        | 0      | 0      | 1        | fx/2 <sup>5</sup> | (262 k   | Hz)      |          |          |         |          |     |
|        | 0      | 1      | 0        | fx/2 <sup>6</sup> | (131 k   | Hz)      |          |          |         |          |     |
|        | 0      | 1      | 1        | fx/2 <sup>7</sup> | (65.5 k  | Hz)      |          |          |         |          |     |
|        | 1      | 0      | 0        | fx/2 <sup>8</sup> | (32.7 k  | Hz)      |          |          |         |          |     |
|        | 1      | 0      | 1        | fx/2°             | (16.4 k  | (Hz)     |          |          |         |          |     |
|        | 1      | 1      | 0        | fx/21             | ° (8.2 k | Hz)      |          |          |         |          |     |

| MDL013 | MDL012 | MDL011 | MDL010 | Baud Rate Generator<br>Input Clock Selection | k  |
|--------|--------|--------|--------|----------------------------------------------|----|
| 0      | 0      | 0      | 0      | fsck/16                                      | 0  |
| 0      | 0      | 0      | 1      | fsck/17                                      | 1  |
| 0      | 0      | 1      | 0      | fscx/18                                      | 2  |
| 0      | 0      | 1      | 1      | fscx/19                                      | 3  |
| 0      | 1      | 0      | 0      | fscx/20                                      | 4  |
| 0      | 1      | 0      | 1      | fscx/21                                      | 5  |
| 0      | 1      | 1      | 0      | fsck/22                                      | 6  |
| 0      | 1      | 1      | 1      | fsck/23                                      | 7  |
| 1      | 0      | 0      | 0      | fscx/24                                      | 8  |
| 1      | 0      | 0      | 1      | fsck/25                                      | 9  |
| 1      | 0      | 1      | 0      | fscx/26                                      | 10 |
| 1      | 0      | 1      | 1      | fsck/27                                      | 11 |
| 1      | 1      | 0      | 0      | fscx/28                                      | 12 |
| 1      | 1      | 0      | 1      | fsck/29                                      | 13 |
| 1      | 1      | 1      | 0      | fsck/30                                      | 14 |
| 1      | 1      | 1      | 1      | Setting prohibited                           | -  |

fx/211 (4.1 kHz)

- Caution If a write to the BRGC01 is performed during communication, the output of baud rate generator may be disrupted, preventing normal communication from continuing. The BRGC01 should therefore not be written to during communication.
- **Remarks 1.** (): at fx = 8.38-MHz operation

1

1

1

- 2. fsck: 5-bit counter source clock
- 3. k: Value set in bits MDL010 to MDL013 ( $0 \le k \le 14$ )

🗖 6427525 0099631 716 🎞

The transmit/receive clock for the baud rate to be generated is obtained by dividing the system clock.

Generating transmit/receive clock for baud rate from system clock

The transmit/receive clock is generated by dividing the system clock. The baud rate generated from the system clock can be calculated from the following expression:

[Baud rate] =  $\frac{fx}{2^{m+1}(k+16)}$  [Hz]

fx: System clock oscillation frequency

m: Value set by TPS0n0 to TPS0n2

 $(1 \le m \le 8 \text{ for UART00}, 4 \le m \le 11 \text{ for UART01})$ 

k: Value set by MDL0n0 to MDL0n3 ( $0 \le k \le 14$ )

Tables 12-2 and 12-3 show the relations between the source clock of the 5-bit counter and the value of m. Table 12-4 shows the relation between the system clock and baud rate.

| TPS002 | TPS001 | TPS000 | 5-Bit Counter Source Clock Selection | m |
|--------|--------|--------|--------------------------------------|---|
| 0      | 0      | 0      | fx/2 (4.19 MHz)                      | 1 |
| 0      | 0      | 1      | fx/2² (2.1 MHz)                      | 2 |
| 0      | 1      | 0      | fx/2 <sup>3</sup> (1.05 MHz)         | 3 |
| 0      | 1      | 1      | fx/2 <sup>4</sup> (524 kHz)          | 4 |
| 1      | 0      | 0      | fx/2 <sup>5</sup> (262 kHz)          | 5 |
| 1      | 0      | 1      | fx/2 <sup>6</sup> (131 kHz)          | 6 |
| 1      | 1      | 0      | fx/2 <sup>7</sup> (65.5 kHz)         | 7 |
| 1      | 1      | 1      | fx/2 <sup>3</sup> (32.7 kHz)         | 8 |

| Table 12-2  | Relations between | Source Clock of | 5-Bit Counter and | Value of m (w | (ith UART00) |
|-------------|-------------------|-----------------|-------------------|---------------|--------------|
| Table 12-2. | neiations between | Source Clock of | 3-Dit Counter and | value of m (w |              |

Remark (): at fx = 8.38-MHz operation

Table 12-3. Relations between Source Clock of 5-Bit Counter and Value of m (with UART01)

| TPS012 | TPS011 | TPS010 | 5-Bit Counter Source Clock Selection | m  |
|--------|--------|--------|--------------------------------------|----|
| 0      | 0      | 0      | fx/2 <sup>4</sup> (524 kHz)          | 4  |
| 0      | 0      | 1      | fx/2 <sup>5</sup> (262 kHz)          | 5  |
| 0      | 1      | 0      | fx/2 <sup>6</sup> (131 kHz)          | 6  |
| 0      | 1      | 1      | tx∕2 <sup>7</sup> (65.5 kHz)         | 7  |
| 1      | 0      | 0      | fx/2 <sup>8</sup> (32.7 kHz)         | 8  |
| 1      | 0      | 1      | fz/2 <sup>9</sup> (16.4 kHz)         | 9  |
| 1      | 1      | 0      | fx/2 <sup>10</sup> (8.2 kHz)         | 10 |
| 1      | 1      | 1      | fx/2 <sup>11</sup> (4.1 kHz)         | 11 |

Remark (): at fx = 8.38-MHz operation

🖬 6427525 0099632 652 🎟

Table 12-4. Relation between the System Clock and Baud Rate

Error (%) 4.1943 BRGC01 63 H 64 H 65 H **BRGC00** Error (%) BRGC01 5.000 70H 66H 50H 50H 70H 10H 10H 10H 10H 10H **BRGC00** Error (%) BRGC01 7.3728 **BRGC00** Error (%) BRGC01 8.000 7AH 6AH 5AH 5AH 72H 5AH 7AH 1AH 0AH **BRGC00** Error (%) -2.0 -2.0 1.10 1.110 1.110 1.110 1.110 1.110 1.110 1.110 1.110 1.110 BRGC01 8.386 **BRGC00** Baud rate (bps) System Clock (zHM) xi 75 110 150 300 600 1200 1200 1200 9600 9600 31250 31250 31250 31250 115200

🛚 6427525 0099633 599 🖿

### CHAPTER 12 SERIAL INTERFACE

### (2) Communication operation

### (a) Data format

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

The specification of character bit length, parity selection, and specification of stop bit length for each data frame is carried out with asynchronous serial interface mode register (ASIM0n).

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



- Start bits..... 1 bit
- Parity bits ..... Even parity/odd parity/0 parity/no parity
- Stop bit(s) ..... 1 bit/2 bits

When 7 bits are selected as the number of character bits, only the lower 7 bits (bits 0 to 6) are valid; in transmission the most significant bit (bit 7) is ignored, and in reception the most significant bit (bit 7) is always "0".

The serial transfer rate is selected by means of the asynchronous serial interface mode register (ASIMOn) and the baud rate generator control register (BRGC0n).

If a serial data receive error is generated, the receive error contents can be determined by reading the status of the asynchronous serial interface status register (ASIS0n).

Remark n = 0, 1

# 6427525 0099634 425 🖬

Powered by ICminer.com Electronic-Library Service CopyRight 2003

### (b) Parity types and operation

The parity bit is used to detect a bit error in the communication data. Normally, the same kind of parity bit is used on the transmitting side and the receiving side. With even parity and odd parity, a one-bit (odd number) error can be detected. With 0 parity and no parity, an error cannot be detected.

### (i) Even parity

### Transmission

The number of bits with a value of "1", including the parity bit, in the transmit data is controlled to be even.

The value of the parity bit is as follows:

Number of bits with a value of "1" in transmit data is odd: 1 Number of bits with a value of "1" in transmit data is even: 0

### Reception

The number of bits with a value of "1", including the parity bit, in the receive data is counted. If it is odd, a parity error occurs.

### (ii) Odd parity

### Transmission

Conversely to the situation with even parity, the number of bits with a value of "1", including the parity bit, in the transmit data is controlled to be odd. The value of the parity bit is as follows:

Number of bits with a value of "1" in transmit data is odd: 0 Number of bits with a value of "1" in transmit data is even: 1

### Reception

The number of bits with a value of "1", including the parity bit, in the receive data is counted. If it is even, a parity error occurs.

### (iii) 0 Parity

When transmitting, the parity bit is set to "0" irrespective of the transmit data. At reception, a parity bit check is not performed. Therefore, a parity error is not generated, irrespective of whether the parity bit is set to "0" or "1".

### (iv) No parity

A parity bit is not added to the transmit data. At reception, data is received assuming that there is no parity bit. Since there is no parity bit, a parity error is not generated.

### 📟 6427525 0099635 361 📟

### (c) Transmission

A transmit operation is started by writing transmit data to the transmit shift register (TXSOn). The start bit, parity bit and stop bit(s) are added automatically.

When the transmit operation starts, the data in the transmit shift register (TXSOn) is shifted out, and when the transmit shift register (TXSOn) is empty, a transmission completion interrupt (INTSTn) is generated.

### Figure 12-10. Asynchronous Serial Interface Transmission Completion Interrupt Timing



Caution Rewriting of the asynchronous serial interface mode register (ASIM0n) should not be performed during a transmit operation. If rewriting of the ASIM0n register is performed during transmission, subsequent transmit operations may not be possible (the normal state is restored by RESET input).

It is possible to determine whether transmission is in progress by software by using a transmission completion interrupt (INTSTn) or the interrupt request flag (STIFn) set by the INTSTn.

Remark n = 0, 1

176

### 🔳 6427525 0099636 2T8 🎟

### (d) Reception

When the RXE0n bit of the asynchronous serial interface mode register (ASIM0n) is set (1), a receive operation is enabled and sampling of the RxD0n pin input is performed.

RxD0n pin input sampling is performed using the serial clock specified by ASIM0n.

When the RxD0n pin input becomes low, the 5-bit counter starts counting, and at the time when the half time determined by specified baud rate has passed, the data sampling start timing signal is output. If the RxD0n pin input sampled again as a result of this start timing signal is low, it is identified as a start bit, the 5-bit counter is initialized and starts counting, and data sampling is performed. When character data, a parity bit and one stop bit are detected after the start bit, reception of one frame of data ends. When one frame of data has been received, the receive data in the shift register is transferred to the receive buffer register (RXB0n), and a reception completion interrupt (INTSR0n) is generated.

If an error is generated, the receive data in which the error was generated is still transferred to RXB0n, and INTSRn is generated.

If the RXE0n bit is reset (0) during the receive operation, the receive operation is stopped immediately. In this case, the contents of RXB0n and ASIS0n are not changed, and INTSRn and INTSERn are not generated.



Figure 12-11. Asynchronous Serial Interface Reception Completion Interrupt Timing

Caution The receive buffer register (RXB0n) must be read even if a receive error is generated. If RXB0n is not read, an overrun error will be generated when the next data is received, and the receive error state will continue indefinitely.

Remark n = 0, 1

6427525 0099637 134 📟

### (e) Receive errors

Three kinds of errors can occur during a receive operation: a parity error, framing error, or overrun error. As a result of data reception, if the error flag is set in the asynchronous serial interface status register (ASISOn), a receive error interrupt (INTSERn) is generated. The receive error interrupt occurs before a receive end interrupt (INTSRn). Receive error causes are shown in Table 12-5.

It is possible to determine what kind of error was generated during reception by reading the contents of the asynchronous serial interface status register (ASIS0n) in the reception error interrupt servicing (INTSERn) (see Figures 12-11 and 12-12).

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

| Receive Errors | Cause                                                                                |
|----------------|--------------------------------------------------------------------------------------|
| Parity error   | Transmission-time parity specification and reception data parity do not match        |
| Framing error  | Stop bit not detected                                                                |
| Overrun error  | Reception of next data is completed before data is read from receive buffer register |

Figure 12-12. Receive Error Timing

# Table 12-5. Receive Error Causes



# Cautions 1. The contents of the ASIS0n register are reset (0) by reading the receive buffer register (RXB0n) or receiving the next data. To ascertain the error contents, ASIS must be read before reading RXB0n.

2. The receive buffer register (RXB0n) must be read even if a receive error is generated. If RXB0n is not read, an overrun error will be generated when the next data is received, and the receive error state will continue indefinitely.

### Remark n = 0, 1

178

### 🖬 6427525 0099638 070 🖿

### 12.4.3 Infrared data transfer (IrDA) mode

Caution The infrared data transfer (IrDA) mode can be used only with UART00.

# (1) Data format

Figure 12-13 shows the format of the IrDA mode in comparison with the data format in UART mode. The IR frame corresponds the bit string of the UART frame that consists of 8 data bits and 1 stop bit. The length of the electrical pulse transmitted or received in the IR frame is 3/16 of a 1-bit cycle. The pulse 3/16 of a 1-bit cycle rises in the middle of the bit cycle (refer to the figure below).



Pulse width = 3/16 bit time







🛚 6427525 0099639 TO7 🎞

### (2) Bit rate and pulse width

Table 12-6 shows the values of the bit rate, permissible bit rate error, and pulse width. Because the minimum pulse width may be 3/16 of the bit cycle or the minimum pulse width of the signal of 115.2 kbps (permissible error: 1.63  $\mu$ s to 22  $\mu$ s), the value is the same at any bit rate.

The maximum pulse width is the sum of bit time 3/16 and 2.5% of the bit cycle or 1.08  $\mu$ s whichever greater.

| Bit Rate<br>(kbits/s) | Permissible Bit Rate<br>Error (% of bit rate) | Minimum Pulse Width<br>(μs) <sup>Note</sup> | Nominal Value of Pulse<br>Width 3/16 (µs) | Maximum Pulse<br>Width (μs) |
|-----------------------|-----------------------------------------------|---------------------------------------------|-------------------------------------------|-----------------------------|
| 2.4                   | +/ 0.87                                       | 1.41                                        | 78.13                                     | 88.55                       |
| 9.6                   | +/- 0.87                                      | 1.41                                        | 19.53                                     | 22.13                       |
| 19.2                  | +/ 0.87                                       | 1.41                                        | 9.77                                      | 11.07                       |
| 38.4                  | +/ 0.87                                       | 1.41                                        | 4.88                                      | 5.96                        |
| 57.6                  | +/- 0.87                                      | 1.41                                        | 3.26                                      | 4.34                        |
| 115.2                 | +/ 0.87                                       | 1.41                                        | 1.63                                      | 2.71                        |

### Table 12-6. Bit Rate and Pulse Width

Note Where a digital noise elimination circuit is used with the microcontroller at a frequency of 1.41 MHz or higher

The maximum pulse width can be calculated as follows where the bit rate is 2.4 kbps.

78.13 + (78.13 × 
$$\frac{16}{3}$$
 × 0.025) = 88.55 [ $\mu$ s]

(3) Baud rate that can be set in IrDA mode

| System Clock fx (MHz) | Baud Rate (bps) |
|-----------------------|-----------------|
| 8.386                 | 131031          |
| 8.000                 | 125000          |
| 7.3728                | 115200          |
| 5.000                 | 78125           |
| 4.1943                | 65536           |

🗖 6427525 0099640 729 📰

### Table 12-7. Baud Rate That Can Be Set in IrDA Mode

# (4) I/O data and internal signal

• Transmission timing



# • Reception timing

Data reception is delayed by half the set baud rate.



## I 6427525 0099641 665 🎟

# PAGE(S) INTENTIONALLY BLANK

182

🔲 6427525 0099642 STL 🔳

Powered by ICminer.com Electronic-Library Service CopyRight 2003

### **CHAPTER 13 INTERRUPT FUNCTIONS**

### **13.1 Types of Interrupt Functions**

The following three types of interrupt functions are available:

### (1) Non-maskable interrupts

This interrupt is unconditionally accepted even in the interrupt disabled status. It is not subject to interrupt priority control and therefore takes precedence over all interrupt requests.

This interrupt generates a standby release signal.

The non-maskable interrupts have one interrupt from the watchdog timer.

### (2) Maskable interrupts

These interrupts are subject to mask control, and can be divided into two groups according to the setting of the priority specification flag register (PROL, PROH): one with higher priority and the other with lower priority. Higher-priority interrupts can nest lower-priority interrupts. The priority when two or more interrupt requests with the same priority occur at the same time is predetermined (refer to **Table 13-1**). This interrupt generates a standby release signal.

As the maskable interrupts, four external interrupts and twelve internal interrupts are available.

### (3) Software interrupts

This is a vectored interrupt generated when the BRK instruction is executed and can be accepted even in the interrupt disabled status. This interrupt is not subject to interrupt priority control.

### 13.2 Interrupt Sources and Configuration

A total of 18 interrupt sources including non-maskable, maskable, and software interrupt sources are available (refer to Table 13-1).

### 🖬 6427525 0099643 438 📰

| Interrupt<br>Type | Note 1<br>Default |         | Interrupt Source                                                      | Internal/ | Vector<br>Table | Note 2<br>Basic<br>Configuration<br>Type |  |
|-------------------|-------------------|---------|-----------------------------------------------------------------------|-----------|-----------------|------------------------------------------|--|
|                   | Priority          | Name    | Trigger                                                               | External  | Address         |                                          |  |
| Non-<br>maskable  | 1                 | INTWDT  | Watchdog timer overflow (when non-<br>maskable interrupt is selected) | Internal  | 0004H           | (A)                                      |  |
| Maskable          | 0                 | INTWDT  | Watchdog timer overflow (when interval timer mode is selected)        |           |                 | (B)                                      |  |
|                   | 1                 | INTPO   | Pin input edge detection                                              | External  | 0006H           | (C)                                      |  |
|                   | 2                 | INTP1   |                                                                       |           | 0008H           |                                          |  |
|                   | 3                 | INTP2   |                                                                       |           | 000AH           |                                          |  |
|                   | 4                 | INTP3   |                                                                       |           | 000CH           |                                          |  |
|                   | 5                 | INTTM7  | TM7 under flow                                                        | Internal  | 000EH           | (B)                                      |  |
|                   | 6                 | INTSER0 | UART00 receive error generation                                       |           | 0010H           |                                          |  |
|                   | 7                 | INTSR0  | UART00 receive termination                                            |           | 0012H           |                                          |  |
|                   | 8                 | INTSTO  | UART00 transmit termination                                           |           | 0014H           |                                          |  |
|                   | 9                 | INTSER1 | UART01 receive error generation                                       |           | 0016H           |                                          |  |
|                   | 10                | INTSR1  | UART01 receive termination                                            |           | 0018H           |                                          |  |
|                   | 11                | INTST1  | UART01 transmit termination                                           |           | 001AH           |                                          |  |
|                   | 12                | INTTM50 | TM50 and CR50 match signal generation                                 |           | 001CH           |                                          |  |
|                   | . 13              | INTTM51 | TM51 and CR51 match signal generation                                 |           | 001EH           |                                          |  |
|                   | 14                | INTTM52 | TM52 and CR52 match signal generation                                 |           | 0020H           |                                          |  |
|                   | 15                | INTAD0  | A/D conversion termination                                            |           | 0022H           |                                          |  |
| Software          |                   | BRK     | Execution of BRK instruction                                          | -         | 003EH           | (D)                                      |  |

Table 13-1. Interrupt Source List

**Notes 1.** The default priority is the priority applicable when more than one maskable interrupt is generated. 0 is the highest priority and 15, the lowest.

🛚 6427525 0099644 374 🎞

2. Basic configuration types (A) to (D) correspond to (A) to (D) on the next pages.

184

Powered by ICminer.com Electronic-Library Service CopyRight 2003

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





### (B) Internal maskable interrupt



### (C) External maskable interrupt



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

# (D) Software interrupt



- IΕ interrupt enable flag
- :
- ISP in-service priority flag :
- MK : interrupt mask flag
- PR : priority specification flag

# 186

# 64275250099646 147 🖿

Powered by ICminer.com Electronic-Library Service CopyRight 2003

# **13.3 Registers Controlling Interrupt Function**

The following six types of registers control the interrupt function:

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

Table 13-2 shows the names of the interrupt request flags, interrupt mask flags, and priority specification flags corresponding to the respective interrupt request sources.

| Interrupt Request Signal Name | Interrupt Request Flag | Interrupt Mask Flag   | Priority Specification Flag |
|-------------------------------|------------------------|-----------------------|-----------------------------|
| INTPO                         | PIFO                   | РМКО                  | PPR0                        |
| INTP1                         | PIF1                   | PMK1                  | PPR1                        |
| INTP2                         | PIF2                   | PMK2                  | PPR2                        |
| INTP3                         | PIF3                   | РМКЗ                  | PPR3                        |
| INTTM7                        | TMIF7                  | TMMK7                 | TMPR7                       |
| INTTM50                       | TMIF50                 | TMMK50                | TMPR50                      |
| INTTM51                       | TMIF51                 | TMMK51                | TMPR51                      |
| INTTM52                       | TMIF52                 | TMMK52                | TMPR52                      |
| INTWDT                        | WDTIF <sup>Note</sup>  | WDTMK <sup>Note</sup> | WDTPR <sup>Note</sup>       |
| INTSERO                       | SERIF0                 | SERMKO                | SERPRO                      |
| INTSRO                        | SRIFO                  | SRMK0                 | SRPRO                       |
| INTSTO                        | STIFO                  | STMK0                 | STPR0                       |
| INTSER1                       | SERIF1                 | SERMK1                | SERPR1                      |
| INTSR1                        | SRIF1                  | SRMK1                 | SRPR1                       |
| INTST1                        | STIF1                  | STMK1                 | STPR1                       |
| INTAD0                        | ADIF                   | ADMK                  | ADPR                        |

Table 13-2. Flags Corresponding to Respective Interrupt Request Sources

Note Interrupt control flag when the watchdog timer is used as an interval timer

| 64275250099647083 **|||** 

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

An interrupt request flag is set to 1 when the corresponding interrupt request is generated or when an instruction is executed, and is cleared to 0 when the interrupt request is accepted, when the RESET signal is input, or when an instruction is executed.

IFOL and IFOH are set by a 1-bit or 8-bit memory manipulation instruction. When using IFOL and IFOH as a 16-bit register IFO, it is set by a 16-bit memory manipulation instruction.

These registers are set to 00H when the RESET signal is input.



# Figure 13-2. Format of Interrupt Request Flag Registers

- Cautions 1. The WDTIF flag can be read/written only when the watchdog timer is used as an interval timer. Clear the WDTIF flag to 0 when the watchdog timer mode 1 is used.
  - 2. Because port 0 is shared with external interrupt inputs, the corresponding interrupt request flag is set when the output mode is specified and output level of a port pin is changed.

To use the port in the output mode, therefore, set the corresponding interrupt mask flag to 1 in advance.

# 6427525 0099648 TLT 💻

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

An interrupt mask flag enables or disables the corresponding maskable interrupt processing and releasing the standby mode.

MK0L and MK0H are set by a 1-bit or 8-bit memory manipulation instruction. When using MK0L and MK0H as a 16-bit register MK0, it is set by a 16-bit memory manipulation instruction.

These registers are reset to FFH when the RESET signal is input.



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

Caution Because port 0 is shared with external interrupt inputs, the corresponding interrupt request flag is set when the output mode is specified and output level of a port pin is changed. To use the port in the output mode, therefore, set the corresponding interrupt mask flag to 1 in advance.

### 6427525 0099649 956 🖿

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

A priority specification flag sets the priority of the corresponding maskable interrupt. PROL and PROH are set by a 1-bit or 8-bit memory manipulation instruction. When using PROL and PROH as a 16-bit register PRO, it is set by a 16-bit memory manipulation instruction. These registers are set to FFH when the RESET signal is input.

### Figure 13-4. Format of Priority Specification Flag Register

| Symbol | $\overline{\mathcal{O}}$ | 6          | 5          | 4          | 3         | 2         | 1        | 0         | Addr | ess  | On reset        | R/W    |  |  |
|--------|--------------------------|------------|------------|------------|-----------|-----------|----------|-----------|------|------|-----------------|--------|--|--|
| PROL   | SRPR<br>0                | SERPR<br>0 | TMPR<br>7  | PPR3       | PPR2      | PPR1      | PPR0     | WDTPR     | FFE  | вн   | FFH             | R/W    |  |  |
|        | 7                        | 6          | 5          | 4          | 3         | 2         | 1        | 0         |      |      |                 |        |  |  |
| PROH   | ADPR                     | TMPR<br>52 | TMPR<br>51 | TMPR<br>50 | STPR<br>1 | SRPR<br>1 | SERPR    | STPR<br>0 | FFE  | ЭH   | FFH             | R/W    |  |  |
|        |                          |            |            |            |           |           | <u> </u> | ]         |      |      |                 |        |  |  |
|        |                          |            |            | 1          |           |           |          |           | ∞PR  | Sele | ects priority   | level. |  |  |
|        |                          |            |            |            |           |           |          |           | 0    | Hig  | n priority lev  | el     |  |  |
|        |                          |            |            |            |           |           |          |           | 1    | Low  | r priority leve | el     |  |  |

190

6427525 0099650 678 🖿

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

EGP and EGN specify the valid edge to be detected on pins P00 to P03.

EGP and EGN can be read or written to with a 1-bit or 8-bit memory manipulation instruction. These registers are set to 00H when the  $\overrightarrow{\text{RESET}}$  signal is input.

# Figure 13-5. Formats of External Interrupt Rising Edge Enable Register and External Interrupt Falling Edge Enable Register



| EGPn | EGNn | Valid edge of INTPn pin (n = 0-3) |
|------|------|-----------------------------------|
| 0    | 0    | Interrupt disable                 |
| 0    | 1    | Falling edge                      |
| 1    | 0    | Rising edge                       |
| 1    | 1    | Both rising and falling edges     |

6427525 0099651 504 💻

#### (5) Program status word (PSW)

The program status word is a register that holds the instruction execution result and current status of interrupt request. An IE flag that enables/disables the maskable interrupts and an ISP flag that controls multiplexed interrupts processing are mapped to this register.

This register can be read or written in 8-bit units. In addition, it can also be manipulated by using a bit manipulation instruction or dedicated instructions (El and Dl). When a vectored interrupt is accepted, and when the BRK instruction is executed, PSW is automatically saved to the stack. At this time, the IE flag is reset to 0. If a maskable interrupt has been accepted the content of the priority flag of that interrupt is transferred to ISP flag. The contents of PSW can also be saved to the stack by the PUSH PSW instruction, and restored from the stack by RETI, RETB or POP PSW instruction.

PSW is set to 02H when the RESET signal is input.



#### Figure 13-6. Configuration of Program Status Word

## 13.4 Interrupt Processing Operation

## 13.4.1 Non-maskable interrupt acceptance operation

The non-maskable interrupt is unconditionally accepted even when interrupts are disabled. It is not subject to interrupt priority control and takes precedence over all other interrupts.

When the non-maskable interrupt request is acknowledged, program status word (PSW) and program counter (PC) are saved to the stack in that order, the IE flag and ISP flag are reset to 0, the contents of the vector table are loaded to the PC, and then program execution branches.

If a new non-maskable interrupt request is generated while the non-maskable interrupt service program is executed, the interrupt request is accepted when the current execution of the non-maskable interrupt service program has been completed (after the RETI instruction has been executed) and one instruction in the main routine has been executed. If two or more new non-maskable interrupt requests are generated while the non-maskable interrupt service program is executed, only one non-maskable interrupt request is accepted after execution of the non-maskable interrupt service program is executed, only one non-maskable interrupt request is accepted after execution of the non-maskable interrupt service program has been completed.







WDTM : watchdog timer WDT : watchdog timer



| CPU processing | Instruction | Instruction         | Saving PSW and PC, and jump to interrupt processing program |
|----------------|-------------|---------------------|-------------------------------------------------------------|
| WDTIF          |             |                     |                                                             |
|                |             |                     |                                                             |
|                |             |                     |                                                             |
|                |             |                     |                                                             |
|                |             |                     |                                                             |
|                |             | 6427525 0099653 387 | 193                                                         |

### Figure 13-9. Accepting Non-Maskable Interrupt Request

(a) When new non-maskable interrupt request is generated while non-maskable interrupt service program is executed



(b) If two new non-maskable interrupt requests are generated while nonmaskable interrupt service program is executed





## 13.4.2 Maskable interrupt acceptance operation

A maskable interrupt can be accepted when the interrupt request flag is set to 1 and the corresponding interrupt mask flag is cleared to 0. A vectored interrupt is accepted in the interrupt enabled status (when the IE flag is set to 1). However, an interrupt with a lower priority cannot be accepted while an interrupt with a higher priority is being processed (when the ISP flag is reset to 0).

The time required to start the interrupt processing after a maskable interrupt request has been generated is as follows:

|               | Minimum Time | Maximum Time <sup>Note</sup> |
|---------------|--------------|------------------------------|
| When xxPR = 0 | 7 clocks     | 32 clocks                    |
| When xxPR = 1 | 8 clocks     | 33 clocks                    |

Table 13-3. Time from Generation of Maskable Interrupt Request to Processing

Note The wait time is maximum when an interrupt request is generated immediately before a division instruction.

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

When two or more maskable interrupt requests are generated at the same time, they are accepted starting from the one assigned the highest priority by the priority specification flag. When interrupts are assigned the same priority, the default priority takes precedence.

A pended interrupt is accepted when the status where it can be accepted is set.

Figure 13-10 shows the algorithm of accepting interrupts.

When a maskable interrupt request is accepted, the program status word (PSW) and program counter (PC) are saved to the stack in that order, IE flag is reset to 0, and the content of the interrupt priority specification flag of the accepted interrupt is transferred to the ISP flag. In addition, the data in the vector table determined for each interrupt request is loaded to the PC, and execution branches.

To return from interrupt processing, use the RETI instruction.

#### | 6427525009965515T 🖿

Figure 13-10. Interrupt Acceptance Program Algorithm



196

🖬 6427525 0099656 096 🎟





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





13.4.3 Software interrupt acceptance operation

The software interrupt can be accepted when the BRK instruction is executed. This interrupt cannot be disabled. When the software interrupt is accepted, the program status word (PSW) and program counter (PC) are saved to the stack in that order, the IE flag is reset to 0, the contents of the vector table (003EH and 003FH) are loaded to the PC, and execution branches.

To return from the software interrupt processing, use the RETB instruction.

Caution Do not use the RETI instruction to return from the software interrupt.

6427525 0099657 T22 🔳

## 13.4.4 Multiplexed interrupt processing

Multiplexed interrupt processing in which another interrupt is accepted while an interrupt is processed can be controlled by priority.

The priority is controlled in two ways: by using the default priority and by using programmable priority that is set by the priority specification flag register (PROL, PROH). When the priority is controlled by the default priority and two or more interrupts are generated at once, interrupt processing is performed according to the priority (default priority) assigned to each interrupt request in advance (refer to **Table 13-1**). The programmable priority control divides the interrupt requests into two groups by the setting of the bit corresponding to PROL, PROH: the one with the higher priority and the other with the lower priority. The interrupt requests that can be multiplexed are shown in the table below.

Table 13-4. Interrupt Requests that Can Be Multiplexed during Interrupt Processing

| Multiple>              | ced Interrupt |                   | Maskable Interrupt Request |        |          |        |  |  |
|------------------------|---------------|-------------------|----------------------------|--------|----------|--------|--|--|
| Interrupt              | Request       | Non-Maskable      | × PF                       | R = 0  | × PR = 1 |        |  |  |
| being accepted         |               | Interrupt Request | IE = 1                     | 1E = 0 | IE = 1   | IE = 0 |  |  |
| Non-maskable interrup  | ×             | ×                 | ×                          | ×      | ×        |        |  |  |
| Maskable interrupt     | ISP = 0       | 0                 | 0                          | ×      | ×        | ×      |  |  |
| processing             | ISP = 1       | 0                 | 0                          | ×      | 0        | ×      |  |  |
| Software interrupt pro | 0             | 0                 | ×                          | 0      | ×        |        |  |  |

Remarks 1. O: can be multiplexed.

- $\times$  : cannot be multiplexed.
- 2. ISP and IE are flags included in PSW.
  - ISP = 0 : interrupt with higher priority is processed.

🖬 6427525 0099658 969 📰

- ISP = 1 : interrupt is not accepted or interrupt with lower priority is processed.
- IE = 0 : accepting interrupt is disabled.
- IE = 1 : accepting interrupt is enabled.
- 3. xxPR is flag included in PR0L, PR0H.
  - $x \times PR = 0$ : higher priority flag
  - $\infty$ PR = 1 : lower priority flag

Powered by ICminer.com Electronic-Library Service CopyRight 2003





### 13.4.5 Pending interrupt

Interrupts are temporarily kept pending in between the following instructions and the instruction to be executed next.

- MOV PSW, #byte
- MOV A, PSW
- MOV PSW, A
- MOV1 PSW. bit, CY
- MOV1 CY, PSW. bit
- AND1 CY, PSW. bit
- OR1 CY, PSW. bit
- XOR1 CY, PSW. bit
- SET1 PSW. bit
- CLR1 PSW. bit
- RETB
- RETI
- PUSH PSW
- POP PSW
- BT PSW. bit, \$addr16
- BF PSW. bit, \$addr16
- · BTCLR PSW. bit, \$addr16
- EI 1
- DI
- · Manipulation instruction to IFOL, IFOH, MKOL, MKOH, PROL, PROH, EGP, EGN registers

Caution The software interrupt (by execution of the BRK instruction) clears the IE flag to 0. Therefore, a maskable interrupt request is not accepted even if generated while the BRK instruction is executed. However, the non-maskable interrupt request is accepted.

#### Figure 13-14. Pending Interrupt Request



- Remarks 1. Instruction N : instruction that keeps interrupt request pending
  - 2. Instruction M : instruction other than that which keeps interrupt request pending

🛚 6427525 0099660 5**17 📖** 

3. The operation of  $\infty$ IF is not affected by the value of  $\times$ PR.



Powered by ICminer.com Electronic-Library Service CopyRight 2003

# CHAPTER 14 EXTERNAL DEVICE EXTENSION FUNCTION

## 14.1 External Device Extension Function

The external device extension function is to connect an external device to areas other than the internal ROM, RAM, and SFR areas. To connect an external device, ports 4 to 6 are used. These ports control address/data, read/write strobe, wait, and address strobe signals.

| Pin Function | Shared by:                   |            |
|--------------|------------------------------|------------|
| Name         |                              |            |
| AD0 to AD7   | Multiplexed address/data bus | P40 to P47 |
| A8 to A15    | Address bus                  | P50 to P57 |
| RD           | Read strobe signal           | P64        |
| WR           | Write strobe signal          | P65        |
| WAIT         | Wait signal                  | P66        |
| ASTB         | Address strobe signal        | P67        |

 Table 14-1. Pin Functions in External Memory Extension Mode

| Table 14-2. | Status of Ports 4 to ( | in External Memor | y Extension Mode |
|-------------|------------------------|-------------------|------------------|
|-------------|------------------------|-------------------|------------------|

| Port                     | Port 4 Port 5 |              |     |      |                    | Port 6             |      |     |   |                    |   |   |   |
|--------------------------|---------------|--------------|-----|------|--------------------|--------------------|------|-----|---|--------------------|---|---|---|
| Extension Mode           | 0-7           | 0            | 1   | 2    | 3                  | 4                  | 5    | 6   | 7 | 4                  | 5 | 6 | 7 |
| Single-chip mode         | Port          | Port         |     |      |                    |                    | Port |     |   |                    |   |   |   |
| 256 bytes extension mode | Address/data  | Port         |     |      |                    | RD, WR, WAIT, ASTB |      |     |   |                    |   |   |   |
| 4 Kbytes extension mode  | Address/data  | 1            | Add | ress |                    |                    | P    | ort |   | RD, WR, WAIT, ASTB |   |   |   |
| 16 Kbytes extension mode | Address/data  | Address Port |     |      | RD, WR, WAIT, ASTB |                    |      |     |   |                    |   |   |   |
| Full address mode        | Address/data  | Address      |     |      | RD, WR, WAIT, ASTB |                    |      |     |   |                    |   |   |   |

Caution When the external wait function is not used, the WAIT pin can be used as a port pin in all the modes.

\_\_\_\_\_

The memory map is as follows when the external device extension function is used.

Figure 14-1. Memory Map when External Device Extension Function Is Used (1/2)

(a) Memory map of µPD780921, 780961

(b) Memory map of µPD780922, 780962



Powered by ICminer.com Electronic-Library Service CopyRight 2003

Figure 14-1. Memory Map when External Device Extension Function Is Used (2/2)

- (c) Memory map of µPD780923, 780963
- (d) Memory map of μPD780924, 780964, and μPD78F0924, 78F0964 with 32 KB flash memory



# 6427525 0099663 226 📖

## 14.2 Registers Controlling External Device Extension Function

The external device expansion function is controlled by the following three registers.

- · Memory extension mode register (MEM)
- · Memory extension wait setting register (MM)
- Memory size select register (IMS)

#### (1) Memory extension mode register (MEM)

MEM is a register that sets an external expansion area. MEM is set by using a 1-bit or 8-bit memory manipulation instruction. Its value is set to 00H at RESET.

#### Figure 14-2. Format of Memory Extension Mode Register

| Symbol | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   | Address | On reset | R/W |
|--------|---|---|---|---|---|-----|-----|-----|---------|----------|-----|
| MEM    | 0 | 0 | 0 | 0 | 0 | MM2 | MM1 | MM0 | FF47H   | 00H      | R/W |

| MM2 | MM1    | ммо     |                          | ingle-chip/                             | Sta        | itus of P40 to F   | P47, P50 to P5 | 7, P64 to P67        | pins                     |  |
|-----|--------|---------|--------------------------|-----------------------------------------|------------|--------------------|----------------|----------------------|--------------------------|--|
|     |        | IVIIVIO | memory extension<br>mode |                                         | P40 to P47 | P50 to P53         | P54, P55       | P56, P57             | P64 to P67               |  |
| 0   | 0      | 0       | Single-c                 | hip mode                                |            | Port mode          |                |                      |                          |  |
| 0   | 1      | 1       |                          | 256B<br>mode                            |            |                    | Port mode      |                      |                          |  |
| 1   | 0      | 0       | Memory                   | 4KB<br>mode                             |            |                    | Port           | P64 = RD<br>P65 = WR |                          |  |
| 1   | 0      | 1       | mode                     | 16KB<br>mode                            | AD0 to AD7 | A8 to A11          |                | Port mode            | P66 = WAIT<br>P67 = ASTB |  |
| 1   | 1      | 1       |                          | Full <sup>Note</sup><br>address<br>mode |            |                    | A12, A13       | A14, A15             |                          |  |
|     | Others |         |                          |                                         |            | Setting prohibited |                |                      |                          |  |

Note The full address mode is a mode in which the entire area of the 64K address space, except the internal ROM, RAM, SFR, and unused areas, can be externally extended.

204

🔲 6427525 0099664 162 🎟

Memory extension wait setting register (MM)
 MM is a register that sets the number of wait states.
 MM is set by using a 1-bit or 8-bit memory manipulation instruction.
 Its value is set to 10H at RESET.

#### Figure 14-3. Format of Memory Extension Wait Setting Register

| Symbol | 7 | 6 | 5   | 4   | 3 | 2 | 1 | 0 | Address | On reset | R/W |
|--------|---|---|-----|-----|---|---|---|---|---------|----------|-----|
| ММ     | 0 | 0 | PW1 | PW0 | 0 | 0 | 0 | 0 | FFF8H   | 10H      | R/W |

| PW1 | PW0 | Controls wait state.              |
|-----|-----|-----------------------------------|
| 0   | 0   | No wait                           |
| 0   | 1   | Wait (1 wait state is inserted)   |
| 1   | 0   | Setting prohibited                |
| 1   | 1   | Wait control by external wait pin |

(3) Memory size select register (IMS)

This register sets the capacities of the internal ROM and internal high-speed RAM. IMS is set by using an 8-bit memory manipulation instruction. Its value is set to CFH at  $\overrightarrow{\text{RESET}}$ .



Figure 14-4. Format of Memory Size Select Register

- Cautions 1. The value of IMS at reset is the same (CFH) for all the models in the µPD780924 and 780964 subseries, regardless of the internal memory capacity. Therefore, be sure to set the value of IMS according to the internal memory capacity of the model used.
  - 2. The external memory space can be expanded in a space other than that specified by IMS, regardless of the internal memory capacity.

| Part Number                | Set Value of IMS |
|----------------------------|------------------|
| μPD780921, 780961          | 42H              |
| μ <b>PD780922</b> , 780962 | 44H              |
| μ <b>PD780923</b> , 780963 | С6Н              |
| μPD780924, 780964          | С8Н              |
| µPD78F0924, 78F0964        | Note             |

| Table 14-3. | Set Value of | f Memory | y Size Se | lect Register |
|-------------|--------------|----------|-----------|---------------|
|-------------|--------------|----------|-----------|---------------|

Note Set C8H, C6H, 44H, or 42H, according to the mask ROM model.

#### 64275250099666 T35 🖿

# 14.3 Timing of External Device Extension Function

The timing control signal output pins used in the external memory extension mode are as follows:

## (1) RD pin (shared by P64)

This pin outputs a read strobe signal when an instruction is fetched or data is accessed from the external memory.

When the internal memory is accessed, the read strobe signal is not output (instead, this pin holds the high level).

## (2) WR pin (shared by P65)

This pin outputs a write strobe signal when the external memory is accessed for data. When the internal memory is accessed, the write strobe signal is not output (this pin holds the high level).

#### (3) WAIT pin (shared by P66)

This pin inputs an external wait signal.

When the external wait signal is not used, the WAIT pin can be used as an I/O port pin. When the internal memory is accessed, the external wait signal is ignored.

#### (4) ASTB pin (shared by P67)

This pin outputs an address strobe signal which is always output regardless of instruction fetch or data access from the external memory.

The address strobe signal is also output when the internal memory is accessed.

#### (5) AD0 to AD7, A8 to A15 pins (shared by P40 to P47, P50 to P57)

These pins output address and data signals. The valid signals are output or input when instructions are fetched or data is accessed from the external memory.

The status of the signal also changes when the internal memory is accessed (the output contents are undefined).

Figures 14-5 to 14-8 show the timing charts.

6427525 0099667 971 🔳



## (a) When no wait state is set (PW1, PW0 = 0, 0)



# (b) When wait state is set (PW1, PW0 = 0, 1)



## (c) When external wait state is set (PW1, PW0 = 1, 1)



## 🖬 6427525 0099668 808 🛤

Figure 14-6. Read Timing of External Memory



 RD
 Lower address
 Read data

 AD0 to AD7
 Lower address
 Read data

 A8 to A15
 Higher address

 Internal wait signal (1 clock wait)
 Internal wait signal (1 clock wait)





#### 📕 6427525 0099669 744 📰



Figure 14-7. Write Timing of External Memory

(c) When external wait state is set (PW1, PW0 = 1, 1)



## 210

🖬 6427525 0099670 466 🛲



(a) When no wait state is set (PW1, PW0 = 0, 0)



(b) When wait state is set (PW1, PW0 = 0, 1)









## 14.4 Example of Connection with Memory

Figure 14-9 shows an example of connecting the  $\mu$ PD780924 and external memories. In this application example, SRAM is connected. In addition, the external device expansion function is used in the full address mode, and 32K bytes of addresses, 0000H to 7FFFH, are allocated to internal ROM; addresses 8000H and higher are allocated to SRAM.







Powered by ICminer.com Electronic-Library Service CopyRight 2003

## **CHAPTER 15 STANDBY FUNCTION**

## 15.1 Standby Function and Configuration

#### 15.1.1 Standby function

The standby function is to reduce the power dissipation of the system and can be effected in the following two modes:

#### (1) HALT mode

This mode is set when the HALT instruction is executed. The HALT mode stops the operation clock of the CPU. The system clock oscillation circuit continues oscillating. This mode does not reduce the power dissipation as much as the STOP mode, but is useful for resuming processing immediately when an interrupt request is generated, or for intermittent operations such as a watch operation.

#### (2) STOP mode

This mode is set when the STOP instruction is executed. The STOP mode stops the system clock oscillation circuit and stops the entire system. The power dissipation of the CPU can be substantially reduced in this mode.

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

The STOP mode can be released by an interrupt request, so that this mode can be used for the intermittent operation. However, certain time is required until the system clock oscillation circuit stabilizes after the STOP mode has been released. If processing must be resumed immediately by using an interrupt request, therefore, use the HALT mode.

In both modes, the previous contents of the registers, flags, and data memory before setting the standby mode are all retained. In addition, the statuses of the output latch of the I/O ports and output buffer are also retained.

- Cautions 1. To set the STOP mode, be sure to stop the operations of the peripheral hardware, and then execute the STOP instruction.
  - To reduce the power dissipation of the A/D converter, clear bit 7 (ADCS0) of A/D converter mode register (ADM0) to 0 to stop the A/D conversion, and then execute the HALT or STOP instruction.



#### 15.1.2 Registers controlling standby function

The wait time during which oscillation is stabilized after the STOP mode has been released by an interrupt request is controlled by the oscillation stabilization time select register (OSTS).

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

This register is set to 04H when the RESET signal is input. Therefore, to release the STOP mode by inputting the RESET signal, the time required to release the mode is 2<sup>17</sup>/fx.



# Figure 15-1. Format of Oscillation Stabilization Time Select Register

Caution The wait time when the STOP mode is released does not include the time required for the clock oscillation to start after the STOP mode has been released (see "a" in the figure below), regardless of whether the mode has been released by the RESET signal or an interrupt request.



6427525 0099674 001 📟

Remarks 1. fx : system clock oscillation frequency

2. (): at fx = 8.38-MHz operation

# 15.2 Operation of Standby Function

## 15.2.1 HALT mode

# (1) Setting and operation status of HALT mode

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

## Table 15-1. Operation Status in HALT Mode

| Item                     |            | Operation Status                                   |
|--------------------------|------------|----------------------------------------------------|
| Clock generation circuit |            | Oscillatable<br>Supply of clock to CPU is stopped. |
| CPU                      |            | Stops operation                                    |
| Port (output latch)      |            | Retains previous status before setting HALT mode.  |
| 10-bit inverter cont     | rol timer  | Operable                                           |
| 8-bit timer/event co     | punter     |                                                    |
| Watchdog timer           |            |                                                    |
| A/D converter            |            |                                                    |
| Real-time output p       | ort        |                                                    |
| Serial interface         | ······     |                                                    |
| External interrupt       |            |                                                    |
| Externally               | AD0 to AD7 | High impedance                                     |
| extended bus line        | A8 to A15  | Retains previous status before setting HALT mode.  |
| ASTB                     |            | Low level                                          |
|                          | WR, RD     | High level                                         |
|                          | WAIT       | High impedance                                     |

### 🔳 6427525 0099675 T48 🔜

#### (2) Releasing HALT mode

The HALT mode can be released by the following three types of sources:

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

The HALT mode is released by an unmasked interrupt request. In this case, if the interrupt is enabled to be accepted, vectored interrupt processing is performed. If the interrupt is disabled, the instruction at the next address is executed.





- **Remarks 1.** The dotted line indicates the case where the interrupt request that has released the standby mode is accepted.
  - 2. The wait time is as follows:
    - When vectored interrupt processing is performed
       : 8 to 9 clocks
    - When vectored interrupt processing is not performed : 2 to 3 clocks

# (b) Releasing by non-maskable interrupt request

The HALT mode is released regardless of whether the interrupt is enabled or disabled, and vectored interrupt processing is performed.

# (c) Releasing by RESET input

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

Figure 15-3. Releasing HALT Mode by RESET Input



**Remark** (): at fx = 8.38 MHz operation

| Releasing Source               | МК∞ | PR×× | IE | ISP | Operation                          |
|--------------------------------|-----|------|----|-----|------------------------------------|
| Maskable interrupt request     | 0   | 0    | 0  | ×   | Executes next address instruction. |
|                                | 0   | 0    | 1  | ×   | Executes interrupt processing.     |
|                                | 0   | 1    | 0  | 1   | Executes next address instruction. |
|                                | 0   | 1    | ×  | 0   |                                    |
|                                | 0   | 1    | 1  | 1   | Executes interrupt processing.     |
|                                | 1   | ×    | ×  | ×   | Retains HALT mode.                 |
| Non-maskable interrupt request | -   | -    | ×  | ×   | Executes interrupt processing.     |
| RESET input                    | -   | _    | ×  | ×   | Resets processing.                 |

#### Table 15-2. Operation after Release of HALT Mode

Remark ×: don't care

## 15.2.2 STOP mode

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

The STOP mode is set by executing the STOP instruction.

- Cautions 1. When the STOP mode is set, X2 pin is internally pulled up circuited to Voot to suppress the current leakage of the crystal oscillation circuit block. Therefore, do not use the STOP mode in a system where the external clock is used as the system clock.
  - 2. Because the standby mode can be released by an interrupt request signal, the standby mode is released as soon as it is set if there is an interrupt source whose interrupt request flag is set and interrupt mask flag is reset. When the STOP mode is set, therefore, the HALT mode is set immediately after the STOP instruction has been executed, the wait times set by the oscillation stabilization time select register (OSTS) elapses, and then an operation mode is set.

The following table shows the operation status in the STOP mode.

| item                                |                    | Operation Status                                                                                                        |  |  |  |
|-------------------------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Clock generation circuit            |                    | Oscillation stopped                                                                                                     |  |  |  |
| CPU                                 |                    | Stops operation.                                                                                                        |  |  |  |
| Output por                          | t (output latch)   | Retains previous status immediately before STOP instruction execution.                                                  |  |  |  |
| 10-bit inve                         | rter control timer | Stops operation.                                                                                                        |  |  |  |
| 8-bit timer/                        | event counter      | Operable only when TI50, TI51, or TI52 is selected as count clock                                                       |  |  |  |
| Watchdog                            | timer              | Stops operation.                                                                                                        |  |  |  |
| A/D converter                       |                    |                                                                                                                         |  |  |  |
| Real-time output port               |                    | Operable when external trigger is used or when TI51 or TI52 is selected as<br>count clock of 8-bit timer/event counter. |  |  |  |
| Serial inte                         | rface              | Stops operation.                                                                                                        |  |  |  |
| External ir                         | nterrupt           | Operable                                                                                                                |  |  |  |
| Externally                          | AD0 to AD7         | High impedance                                                                                                          |  |  |  |
| extended A8 to A15<br>bus line ASTB |                    | Retains previous status immediately before STOP instruction execution.                                                  |  |  |  |
|                                     |                    | Low level                                                                                                               |  |  |  |
|                                     | WR, RD             | High level                                                                                                              |  |  |  |
|                                     | WAIT               | High impedance                                                                                                          |  |  |  |

## Table 15-3. Operation Status in STOP Mode

🔳 6427525 0099679 693 📟

-

#### (2) Releasing STOP mode

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

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

The STOP mode can be released by an unmasked interrupt request. In this case, if the interrupt is enabled to be accepted, vectored interrupt processing is performed, after the oscillation stabilization time has elapsed. If the interrupt is disabled to be accepted, the instruction at the next address is executed.





**Remark** The dotted line indicates the case where the interrupt request that has released the standby mode is accepted.

220

L 64275250099680305 🖿

# (b) Releasing by RESET input

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



Figure 15-5. Releasing STOP Mode by RESET Input

**Remark** (): at fx = 8.38-MHz operation

| Releasing Source           | MKxx | PR×x | IE | ISP | Operation                          |
|----------------------------|------|------|----|-----|------------------------------------|
| Maskable interrupt request | 0    | 0    | 0  | ×   | Executes next address instruction. |
|                            | 0    | 0    | 1  | ×   | Executes interrupt processing.     |
|                            | 0    | 1    | 0  | 1   | Executes next address instruction. |
|                            | 0    | 1    | ×  | 0   |                                    |
|                            | 0    | 1    | 1  | 1   | Executes interrupt processing.     |
|                            | 1    | ×    | ×  | ×   | Retains STOP mode.                 |
| RESET input                | -    | -    | ×  | ×   | Resets processing.                 |

| Table 15-4. | Operation a | fter Release | of STOP | Mode |
|-------------|-------------|--------------|---------|------|
|-------------|-------------|--------------|---------|------|

Remark ×: don't care

## 6427525 0099681 241 📖

-----

[MEMO]

# PAGE(S) INTENTIONALLY BLANK

222

🔳 6427525 0099682 188 🔳

Powered by ICminer.com Electronic-Library Service CopyRight 2003

## **CHAPTER 16 RESET FUNCTION**

The reset signal can be effected by the following two methods:

- (1) External reset input from RESET pin
- (2) Internal reset by inadvertent loop time detection by watchdog timer

There is no functional difference between the external reset and internal reset, and execution of the program is started from addresses written to addresses 0000H and 0001H when the RESET signal is input.

The reset function is effected when a low-level signal is input to the RESET pin or when an overflow occurs in the watchdog timer. As a result, each hardware enters the status shown in Table 16-1. Each pin goes into a high-impedance state while the RESET signal is input, and during the oscillation stabilization time immediately after the reset function has been released.

When a high-level signal is input to the  $\overrightarrow{\text{RESET}}$  pin, the reset function is released, and program execution is started after oscillation stabilization time (2<sup>17</sup>/fx) has elapsed. The reset function effected by an overflow in the watchdog timer is automatically released after reset, and program execution is started after the oscillation stabilization time (2<sup>17</sup>/ fx) has elapsed (refer to **Figures 16-2** to 16-4).

Cautions 1. Input a low-level signal to the RESET pin for 10  $\mu$ s or longer to execute external reset.

- 2. Oscillation of the system clock is stopped while the RESET signal is input.
- 3. To release the STOP mode by the RESET input, the contents in the STOP mode are retained while the RESET signal is input. However, the port pins go into a high-impedance state.



Figure 16-1. Block Diagram of Reset Function



Figure 16-2. Reset Timing by RESET Input

|                                        | Status after Reset                                       |                             |
|----------------------------------------|----------------------------------------------------------|-----------------------------|
| Program counter (PC) <sup>Note 1</sup> | Contents of reset vector table<br>(0000H, 0001H) are set |                             |
| Stack pointer (SP)                     |                                                          | Undefined                   |
| Program status word (PSW)              |                                                          | 02H                         |
| RAM                                    | Data memory                                              | Undefined <sup>Note 2</sup> |
|                                        | General-purpose register                                 | Undefined <sup>Note 2</sup> |
| Port (output latch)                    | Ports 0 to 3 (P0 to P3)                                  | 00Н                         |
|                                        | Ports 4 to 6 (P4 to P6)                                  | Undefined                   |
| Port mode register (PM0, PM            | 12 to PM6)                                               | FFH                         |
| Pull-up resistor option register       | er (PU0, PU2 to PU6)                                     | 00Н                         |
| Processor clock control regis          | iter (PCC)                                               | 04H                         |
| Memory extension mode reg              | 00H                                                      |                             |
| Memory extension wait settir           | 10H                                                      |                             |
| Memory size select register            | CFHNote 3                                                |                             |
| Oscillation stabilization time         | select register (OSTS)                                   | 04H                         |
| Real-time output port                  | Mode register (RTPM0)                                    | 00H                         |
|                                        | Control register (RTPC0)                                 | 00Н                         |
|                                        | Buffer register (RTBL0, RTBH0)                           | 00Н                         |
| 10-bit inverter control timer          | Compare register (CM0 to CM2)                            | 00Н                         |
|                                        | Compare register (CM3)                                   | FFH                         |
|                                        | Buffer register (BFCM0 to BFCM2)                         | 000H                        |
|                                        | Buffer register (BFCM3)                                  | OFFH                        |
|                                        | Reload register (DTIME)                                  | FFH                         |
|                                        | Control register (TMC7)                                  | 00Н                         |
|                                        | Mode register (TMM7)                                     | 00H                         |
| 8-bit timer/event counter              | Timer register (TM50 to TM52)                            | оон                         |
|                                        | Compare register (CM50 to CM52)                          | Undefined                   |
|                                        | Clock select register (TCL50 to TCL52)                   | 00H                         |
|                                        | Mode control register (TMC50 to TMC52)                   | 04H                         |

#### Table 16-1. Status of Each Hardware after Reset (1/2)

Notes 1. Only the contents of the PC among hardware become undefined during reset input and oscillation stabilization time wait. The other status is not different from that after reset as above.

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

3. The initial value of this register is CFH. Set the following value to this register of each version.

| μPD780921, 780961:   | 42 H                                              |
|----------------------|---------------------------------------------------|
| µPD780922, 780962:   | 44 H                                              |
| μPD780923, 780963:   | С6 Н                                              |
| μPD780924, 780964:   | С8 Н                                              |
| µPD78F0924, 78F0964: | Value corresponding to those of mask ROM versions |

🖬 6427525 0099685 997 📟

|                  | Hardware                                                          | Status after Reset |
|------------------|-------------------------------------------------------------------|--------------------|
| Watchdog timer   | Clock select register (WDCS)                                      | 00H                |
|                  | Mode register (WDTM)                                              | 00H                |
| Serial interface | Asynchronous serial interface mode register<br>(ASIM00, ASIM01)   | 00H                |
|                  | Asynchronous serial interface status register<br>(ASIS00, ASIS01) | оон                |
|                  | Transmit shift register (TXS00, TXS01)                            | FFH                |
|                  | Receive buffer register (RXB00, RXB01)                            | FFH                |
|                  | Baud rate generator control register<br>(BRGC00, BRGC01)          | 00H                |
| A/D converter    | Mode register (ADM0)                                              | 00H                |
|                  | Conversion result register (ADCR0)                                | Undefined          |
|                  | Analog input channel specification register (ADS0)                | 00H                |
| Interrupt        | Request flag register (IF0L, IF0H)                                | 00H                |
|                  | Mask flag register (MK0L, MK0H)                                   | FFH                |
|                  | Priority specification flag register (PR0L, PR0H)                 | FFH                |
|                  | External interrupt rising edge enable register (EGP)              | 00H                |
|                  | External interrupt falling edge enable register (EGN)             | 00H                |

Table 16-1. Status of Each Hardware after Reset (2/2)

📟 6427525 0099686 823 📟

Powered by ICminer.com Electronic-Library Service CopyRight 2003

## CHAPTER 17 µPD78F0924, 78F0964

Data can be written to the flash memory with the device mounted on the target system (on-board). Write data to the flash memory by connecting the Flashpro to the host machine and target system.

Remark Flashpro is a product of Naitou Densei Machidaseisakusho Co., Ltd.

# 17.1 Selecting Communication Mode

Data are written to the flash memory by using the Flashpro and by means of serial communication. Select a communication mode from those listed in Table 17-1. To select a communication mode, use the format shown in Figure 17-1. Each communication mode is selected by the number of VPP pulses shown in Table 17-1.

| Table 17-1. | Communication | Modes |
|-------------|---------------|-------|
|-------------|---------------|-------|

| Communication Mode                 | Number of Channels | Pins Used                                                                                                     | Number of VPP Pulses |  |
|------------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------|----------------------|--|
| UART                               | 2                  | RxD00/P20<br>TxD00/P21                                                                                        | 8                    |  |
|                                    |                    | RxD01/P22<br>TxD01/P23                                                                                        | 9                    |  |
| Pseudo 3-wire mode <sup>Note</sup> | 2                  | P24/TI50/TO50 (serial data input)<br>P25/TI51/TO51 (serial data output)<br>P26/TI52/TO52 (serial clock input) | 12                   |  |
|                                    |                    | P34/RTP4 (serial data input)<br>P35/RTP5 (serial data output)<br>P36/RTP6 (serial clock input)                | 13                   |  |

Note Serial transfer is executed by controlling the port by software.

Caution Be sure to select a communication mode by specifying the number of VPP pulses shown in Table 17-1.





227

Powered by ICminer.com Electronic-Library Service CopyRight 2003

# 17.2 Function of Flash Memory Programming

Data is written to the flash memory by transmitting or receiving commands and data in the selected communication mode. The major functions are listed in Table 17-2.

| Table 17-2. | Maior Functions | of Flash Memory | Programming |
|-------------|-----------------|-----------------|-------------|
|-------------|-----------------|-----------------|-------------|

| Function          | Description                                                                                        |
|-------------------|----------------------------------------------------------------------------------------------------|
| Batch erase       | Erases all contents of memory.                                                                     |
| Batch blank check | Checks erased status of entire memory.                                                             |
| Data write        | Writes data to flash memory based on write start address and number of data (bytes) to be written. |
| Batch verify      | Compares all contents of memory with input data.                                                   |

228

🖬 6427525 0099688 6T6 🔜

## 17.3 Connecting Flashpro

Connection between the Flashpro and  $\mu$ PD78F0924 (or  $\mu$ PD78F0964) differs depending on the communication mode. Figures 17-2 and 17-3 show the connections in the respective communication modes.





**Note** n = 1, 2







#### 🛚 6427525 0099689 532 📖

229

# PAGE(S) INTENTIONALLY BLANK

230

6427525 0099690 254 🔳

Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### **CHAPTER 18 INSTRUCTION SET**

This chapter lists the instruction set of the  $\mu$ PD780924 and 780964 subseries. For the details of the operation and machine language (instruction code) of each instruction, refer to 78K/0 Series User's Manual - Instruction (IEU-1372).

.

# 🔳 6427525 0099691 190 🛲

## 18.1 Legend

#### 18.1.1 Operand representation and description formats

In the operand field of each instruction, an operand is described according to the description format for operand representation of that instruction (for details, refer to the assembler specifications). Some operands may be described in two or more description formats. In this case, select one of them. Uppercase characters, #, !, \$, and [] are keywords and must be described as is. The meanings of the symbols are as follows:

| • | # | : | immediate data   | • | \$ |   | : | relative address |
|---|---|---|------------------|---|----|---|---|------------------|
| ٠ | ! | : | absolute address | ٠ | [  | 1 | : | indirect address |

To describe immediate data, also describe an appropriate numeric value or label. To describe a label, be sure to describe #, !, \$, or [].

Register description formats r or rp for an operand can be described as a function name (such as X, A, or C) or absolute name (the name in parentheses in the table below, such as R0, R1, or R2).

| Representation | Description Format                                                                                                       |
|----------------|--------------------------------------------------------------------------------------------------------------------------|
| г              | X (R0), A (R1), C (R2), B (R3), E (R4), D (R5), L (R6), H (R7)                                                           |
| rp -           | AX (RP0), BC (RP1), DE (RP2), HL (RP3)                                                                                   |
| sfr            | Special function register symbol <sup>Note</sup>                                                                         |
| strp           | Special function register symbol (only even address of register that can be manipulated in 16-bit units) <sup>Note</sup> |
| saddr          | FE20H to FF1FH immediate data or label                                                                                   |
| saddrp         | FE20H to FF1FH immediate data or label (even address only)                                                               |
| addr16         | 0000H to FFFFH immediate data or label                                                                                   |
|                | (even address only for 16-bit data transfer instruction)                                                                 |
| addr11         | 0800H to 0FFFH immediate data or label                                                                                   |
| addr5          | 0040H to 007FH immediate data or label (even address only)                                                               |
| word           | 16-bit immediate data or label                                                                                           |
| byte           | 8-bit immediate data or label                                                                                            |
| bit            | 3-bit immediate data or label                                                                                            |
| RBn            | RB0 to RB3                                                                                                               |

#### Table 18-1. Operand Representation and Description Formats

Note FFD0H to FFDFH cannot be addressed.

Remark For the symbols of the special function registers, refer to Table 3-6 Special Function Register List.

232

**6427525 0099692 027** 

# 18.1.2 Description of operation column

| 0.1.2    | Des | scription of operation column                                       |
|----------|-----|---------------------------------------------------------------------|
| Α        | :   | A register; 8-bit accumulator                                       |
| Х        | :   | X register                                                          |
| В        | :   | B register                                                          |
| С        | :   | C register                                                          |
| D        | :   | D register                                                          |
| Е        | :   | E register                                                          |
| н        | :   | H register                                                          |
| L        | :   | L register                                                          |
| AX       | :   | AX register pair; 16-bit accumulator                                |
| BC       | :   | BC register pair                                                    |
| DE       | :   | DE register pair                                                    |
| HL       | :   | HL register pair                                                    |
| PC       | :   | program counter                                                     |
| SP       | :   | stack pointer                                                       |
| PSW      | :   | program status word                                                 |
| CY       | :   | carry flag                                                          |
| AC       | :   | auxiliary carry flag                                                |
| Z        | :   | zero flag                                                           |
| RBS      | :   | register bank select flag                                           |
| IE       | :   | interrupt request enable flag                                       |
| NMIS     | :   | non-maskable interrupt processing flag                              |
| ()       | :   | memory contents indicated by contents of address or register in ( ) |
| Хн, Хц   | :   | higher 8 bits and lower 8 bits of 16-bit register                   |
| ^        | :   | logical product (AND)                                               |
| V        | :   | logical sum (OR)                                                    |
| ₩        | :   | exclusive logical sum (exclusive OR)                                |
| <u> </u> | :   | inverted data                                                       |
| addr1    | 6:  | 16-bit immediate data or label                                      |
| jdisp8   | :   | signed 8-bit data (displacement value)                              |
|          |     |                                                                     |

# 18.1.3 Description in flag operation column

| (Blank) : | not | affected |
|-----------|-----|----------|
|-----------|-----|----------|

- 0 : cleared to 0
- 1 : set to 1
- × : set/cleared according to result
- R : value saved before is restored

🖬 6427525 0099693 T63 🖿

\_\_\_\_\_

-----

# 18.2 Operation List

| Instruction | Mnemonic  | Operand        | D. do | c      | lock   | Operation       |   | Fia     | g   |
|-------------|-----------|----------------|-------|--------|--------|-----------------|---|---------|-----|
| Group       | Witemorac | Operand        | Byte  | Note 1 | Note 2 |                 | z | AC      | CCY |
| 8-bit data  | MOV       | r, #byte       | 2     | 4      | -      | r ← byte        |   | <u></u> |     |
| transfer    |           | saddr, #byte   | 3     | 6      | 7      | (saddr) ← byte  |   |         |     |
|             |           | sfr, #byte     | 3     | -      | 7      | sfr ← byte      |   |         |     |
|             |           | A, r Note 3    | 1     | 2      | -      | A ← r           |   |         |     |
|             |           | r, A Note 3    | 1     | 2      | -      | r ← A           |   |         |     |
|             |           | A, saddr       | 2     | 4      | 5      | A ← (saddr)     | Τ |         |     |
|             |           | saddr, A       | 2     | 4      | 5      | (saddr) ← A     |   |         |     |
|             |           | A, sfr         | 2     | -      | 5      | A ← sfr         | Τ |         |     |
|             |           | str, A         | 2     | -      | 5      | sfr ← A         |   |         |     |
|             |           | A, laddr16     | · 3   | 8      | 9 + n  | A ← (addr16)    |   |         |     |
|             |           | laddr16, A     | 3     | 8      | 9 + m  | (addr16) ← A    |   |         | -   |
|             |           | PSW, #byte     | 3     | -      | 7      | PSW ← byte      | × | ×       | ×   |
|             |           | A, PSW         | 2     | -      | 5      | A ← PSW         | Τ |         |     |
|             |           | PSW, A         | 2     | -      | 5      | PSW ← A         | × | ×       | ×   |
|             |           | A, [DE]        | 1     | 4      | 5 + n  | A ← (DE)        |   |         |     |
|             |           | [DE], A        | 1     | 4      | 5 + m  | (DE) ← A        |   |         |     |
|             |           | A, [HL]        | 1     | 4      | 5 + n  | A ← (HL)        |   |         |     |
|             |           | [HL], A        | 1     | 4      | 5 + m  | (HL) ← A        |   |         |     |
|             |           | A, [HL + byte] | 2     | 8      | 9 + n  | A ← (HL + byte) | 1 |         |     |
|             |           | [HL + byte], A | 2     | 8      | 9 + m  | (HL + byte) ← A | 1 |         |     |
|             |           | A, [HL + B]    | 1     | 6      | 7 + n  | A ← (HL + B)    | 1 |         |     |
|             |           | (HL + B], A    | 1     | 6      | 7 + m  | (HL + B) ← A    | Ì |         |     |
|             |           | A, [HL + C]    | 1     | 6      | 7 + n  | A ← (HL + C)    | 1 |         |     |
|             | ſ         | [HL + C], A    | 1     | 6      | 7 + m  | (HL + C) ← A    | 1 |         |     |

Notes 1. When the internal high-speed RAM area is accessed or when an instruction that does not access data is executed

2. When an area other than the internal high-speed RAM area is accessed

3. Except r = A

2. The number of clocks shown is when the program is stored in the internal ROM area.

🖬 6427525 0099694 9TT 🛤

3. n indicates the number of wait states when the external memory extension area is read.

4. m indicates the number of wait states when the external memory extension area is written.

234

Powered by ICminer.com Electronic-Library Service CopyRight 2003

Remarks 1. One clock of an instruction is equal to one CPU clock (fcpu) selected by processor clock control register (PCC).

| Instruction      | Magmania | 0              |        | <b>D</b> . 44 | c      | lock       | Oracitas                     |           | Flag | g  |
|------------------|----------|----------------|--------|---------------|--------|------------|------------------------------|-----------|------|----|
| Group            | Mnemonic | Operand        |        | Byte          | Note 1 | Note 2     | Operation                    | z         | AC   | CY |
| 8-bit data       | хсн      | A, r N         | lote 3 | 1             | 2      |            | A ↔ r                        | $\square$ |      |    |
| transfer         |          | A, saddr       |        | 2             | 4      | 6          | A ↔ (saddr)                  | T         |      |    |
|                  |          | A, sfr         |        | 2             | -      | 6          | A ↔ sfr                      | 1         |      |    |
|                  |          | A, laddr16     |        | 3             | 8      | 10 + n + m | A ↔ (addr16)                 | Τ         |      |    |
|                  |          | A, [DE]        |        | 1             | 4      | 6+n+m      | A ↔ (DE)                     | Ι         |      |    |
|                  |          | A, (HL)        |        | 1             | 4      | 6 + n + m  | A ↔ (HL)                     |           |      |    |
|                  |          | A, [HL + byte] |        | 2             | 8      | 10 + n + m | A ↔ (HL + byte)              |           |      |    |
|                  |          | A, [HL + B]    |        | 2             | 8      | 10 + n + m | A ↔ (HL + B)                 |           |      |    |
|                  |          | A, [HL + C]    |        | 2             | 8      | 10 + n + m | A ↔ (HL + C)                 |           |      |    |
| 16-bit           | MOVW     | rp, #word      |        | 3             | 6      | -          | rp ← word                    |           |      |    |
| data<br>transfer |          | saddrp, #word  |        | 4             | 8      | 10         | (saddrp) ← word              |           |      |    |
| 11212161         |          | sfrp, #word    |        | 4             | -      | 10         | sfrp ← word                  |           |      |    |
|                  |          | AX, saddrp     |        | 2             | 6      | 8          | AX ← (saddrp)                |           |      |    |
|                  |          | saddrp, AX     |        | 2             | 6      | 8          | (saddrp) ← AX                |           |      |    |
|                  |          | AX, sfrp       |        | 2             | -      | 8          | AX ← sfrp                    |           |      |    |
|                  |          | sfrp, AX       |        | 2             | -      | 8          | sfrp ← AX                    |           |      |    |
|                  |          | AX, m N        | lote 4 | 1             | 4      | -          | AX ← rp                      |           |      |    |
|                  |          | rp, AX N       | lote 4 | 1             | 4      | -          | rp ← AX                      |           |      |    |
|                  |          | AX, laddr16    |        | 3             | 10     | 12 + 2n    | AX ← (addr16)                |           |      |    |
|                  |          | laddr16, AX    |        | 3             | 10     | 12 + 2m    | (addr16) ← AX                |           |      |    |
|                  | хснw     | AX, rp N       | lote 4 | 1             | 4      | _          | AX ↔ rp                      | 1         |      |    |
| 8-bit            | ADD      | A, #byte       |        | 2             | 4      | -          | A, CY ← A + byte             | ×         | ×    | ×  |
| operation        |          | saddr, #byte   |        | З             | 6      | 8          | (saddr), CY ← (saddr) + byte | ×         | ×    | ×  |
|                  |          | A, r N         | lote 3 | 2             | 4      | -          | A, CY ← A + r                | ×         | ×    | ×  |
|                  |          | r, A           |        | 2             | 4      |            | $r, CY \leftarrow r + A$     | ×         | ×    | ×  |
|                  |          | A, saddr       |        | 2             | 4      | 5          | A, CY ← A + (saddr)          | ×         | ×    | ×  |
|                  |          | A, laddr16     |        | 3             | 8      | 9 + n      | A, CY ← A + (saddr16)        | ×         | ×    | ×  |
|                  |          | A, [HL]        |        | 1             | 4      | 5 + n      | A, CY ← A + (HL)             | ×         | ×    | ×  |
|                  |          | A, [HL + byte] |        | 2             | 8      | 9 + n      | A, CY ← A + (HL + byte)      | ×         | ×    | ×  |
|                  |          | A, [HL + B]    |        | 2             | 8      | 9 + n      | A, CY ← A + (HL + B)         | ×         | ×    | ×  |
|                  |          | A, [HL + C]    |        | 2             | 8      | 9 + n      | A, CY ← A + (HL + C)         | ×         | ×    | ×  |

2. When an area other than the internal high-speed RAM area is accessed

3. Except r = A

- 4. Only when rp = BC, DE, HL
- Remarks 1. One clock of an instruction is equal to one CPU clock (fcpu) selected by processor clock control register (PCC).
  - 2. The number of clocks shown is when the program is stored in the internal ROM area.
  - 3. n indicates the number of wait states when the external memory extension area is read.
  - 4. m indicates the number of wait states when the external memory extension area is written.

🖬 6427525 0099695 836 🎟

| Instruction | Mnemonic   | Operand        | Byte | <b>_</b> | Clock  |                                                                            |   | Fia | ıg                      |
|-------------|------------|----------------|------|----------|--------|----------------------------------------------------------------------------|---|-----|-------------------------|
| Group       | MITATIONIC | Operand        | Byte | Note 1   | Note 2 | Operation                                                                  | z | AC  | CCI                     |
| 8-bit       | ADDC       | A, #byte       | 2    | 4        | -      | A, CY $\leftarrow$ A + byte + CY                                           | × | ×   | ×                       |
| operation   |            | saddr, #byte   | 3    | 6        | 8      | (saddr), CY ← (saddr) + byte + CY                                          | × | ×   | ×                       |
|             |            | A, r Note 3    | 2    | 4        | -      | $A, CY \leftarrow A + r + CY$                                              | × | ×   | ×                       |
|             |            | r, A           | 2    | 4        | -      | $r, CY \leftarrow r + A + CY$                                              | × | ×   | ×                       |
|             |            | A, saddr       | 2    | 4        | 5      | A, CY ← A + (saddr) + CY                                                   | × | ×   | ×                       |
| s           |            | A, laddr16     | 3    | 8        | 9 + n  | A, CY ← A + (addr16) + CY                                                  | × | ×   | ×                       |
|             |            | A, [HL]        | 1    | 4        | 5 + n  | A, CY $\leftarrow$ A + (HL) + CY                                           | × | ×   | ×                       |
|             |            | A, [HL + byte] | 2    | 8        | 9 + n  | A, CY ← A + (HL + byte) + CY                                               | × | ×   | ×                       |
|             |            | A, [HL + B]    | 2    | 8        | 9 + n  | A, CY $\leftarrow$ A + (HL + B) + CY                                       | × | ×   | ×                       |
|             |            | A, [HL + C]    | 2    | 8        | 9 + n  | A, CY $\leftarrow$ A + (HL + C) + CY                                       | × | ×   | ×                       |
|             | SUB        | A, #byte       | 2    | 4        | -      | A, CY ← A – byte                                                           | × | ×   | ×                       |
|             |            | saddr, #byte   | 3    | 6        | 8      | (saddr), CY ← (saddr) - byte                                               | × | ×   | ×                       |
|             |            | A, r Note 3    | 2    | 4        | -      | A, CY ← A − r                                                              | × | ×   | ×                       |
|             |            | r, A           | 2    | 4        | -      | $r_c CY \leftarrow r - A$                                                  | × | ×   | ×                       |
|             | H          | A, saddr       | 2    | 4        | 5      | A, CY ← A - (saddr)                                                        | × | ×   | ×                       |
|             |            | A, laddr16     | 3    | 8        | 9 + n  | A, CY ← A - (addr16)                                                       | × | x   | ×                       |
|             |            | A, [HL]        | 1    | 4        | 5 + n  | A, CY ← A - (HL)                                                           | × | ×   | ×                       |
|             |            | A, [HL + byte] | 2    | 8        | 9 + n  | A, CY ← A – (HL + byte)                                                    | × | ×   | ×                       |
|             |            | A, [HL + B]    | 2    | 8        | 9 + n  | A, CY ← A – (HL + B)                                                       | × | ×   | ×                       |
|             |            | A, [HL + C]    | 2    | 8        | 9 + n  | A, CY $\leftarrow$ A – (HL + C)                                            | × | ×   | x                       |
|             | SUBC       | A, #byte       | 2    | 4        | -      | A, CY $\leftarrow$ A – byte – CY                                           | × | ×   | ×                       |
|             |            | saddr, #byte   | 3    | 6        | 8      | (saddr), CY ← (saddr) - byte - CY                                          | × | ×   | ×                       |
|             |            | A, r Note 3    | 2    | 4        | -      | A, $CY \leftarrow A - r - CY$                                              | × | ×   | ×                       |
|             | 1          | r, A           | 2    | 4        | -      | $\mathbf{r}, \mathbf{CY} \leftarrow \mathbf{r} - \mathbf{A} - \mathbf{CY}$ | × | ×   | ×                       |
|             | 4          | A, saddr       | 2    | 4        | 5      | A, CY ← A - (saddr) - CY                                                   | × | ×   | ×                       |
|             |            | A, laddr16     | 3    | 8        | 9 + n  | A, CY ← A - (addr16) - CY                                                  | × | ×   | ×                       |
|             | [          | A, [HL]        | 1    | 4        | 5+n    | A, CY ← A - (HL) - CY                                                      | × | ×   | ×                       |
|             | 4          | A, [HL + byte] | 2    | 8        | 9 + n  | A, CY ← A - (HL + byte) - CY                                               | × | ×   | ×                       |
|             | 4          | A, [HL + B]    | 2    | 8        | 9 + n  | A, CY ← A - (HL + B) - CY                                                  | × | ×   | ×                       |
|             |            | A, [HL + C]    | 2    | 8        | 9+n    | A, CY $\leftarrow$ A – (HL + C) – CY                                       | × | ×   | $\overline{\mathbf{x}}$ |

2. When an area other than the internal high-speed RAM area is accessed

3. Except r = A

Remarks 1. One clock of an instruction is equal to one CPU clock (fcpu) selected by processor clock control register (PCC).

- 2. The number of clocks shown is when the program is stored in the internal ROM area.
- 3. n indicates the number of wait states when the external memory extension area is read.

236

🔳 6427525 0099696 772 📕

| Instruction | Mnemonic | Operand        | Byte | c      | lock   | Occuption                           |   | Flag |
|-------------|----------|----------------|------|--------|--------|-------------------------------------|---|------|
| Group       |          | Operand        | Dyle | Note 1 | Note 2 | Operation                           | z | ACCY |
| 8-bit       | AND      | A, #byte       | 2    | 4      | -      | A ← A∧byte                          | × | ·    |
| operation   |          | saddr, #byte   | 3    | 6      | 8      | (saddr) ← (saddr) ^ byte            | × |      |
|             |          | A, r Note 3    | 2    | 4      | -      | $A \leftarrow A \wedge r$           | × |      |
|             |          | r. A           | 2    | 4      | -      | r ← r∧A                             | × | ,    |
|             |          | A, saddr       | 2    | 4      | 5      | $A \leftarrow A \land (saddr)$      | × |      |
|             |          | A, laddr16     | 3    | 8      | 9 + n  | $A \leftarrow A \land (addr16)$     | × |      |
|             |          | A, [HL]        | 1    | 4      | 5 + n  | $A \leftarrow A \land (HL)$         | × |      |
|             |          | A, [HL + byte] | 2    | 8      | 9 + n  | A ← A ∧ (HL + byte)                 | × |      |
|             |          | A, [HL + B]    | 2    | 8      | 9 + n  | $A \leftarrow A \land (HL + B)$     | × |      |
|             |          | A, [HL + C]    | 2    | 8      | 9 + n  | $A \leftarrow A \land (HL + C)$     | × |      |
|             | OR       | A, #byte       | 2    | 4      | -      | A ← A∨byte                          | × |      |
|             |          | saddr, #byte   | 3    | 6      | 8      | (saddr) ← (saddr)∨byte              | × |      |
|             |          | A, r Note 3    | 2    | 4      | -      | A ← A∨r                             | × |      |
|             |          | r, A           | 2    | 4      | _      | r ← r∨A                             | × |      |
|             |          | A, saddr       | 2    | 4      | 5      | A ← A∨(saddr)                       | × |      |
|             |          | A, laddr16     | 3    | 8      | 9 + n  | A ← A∨(addr16)                      | × |      |
|             |          | A, [HL]        | 1    | 4      | 5 + n  | A ← A∨(HL)                          | × |      |
|             |          | A, [HL + byte] | 2    | 8      | 9 + n  | A ← A∨(HL + byte)                   | × |      |
|             |          | A, [HL + B]    | 2    | 8      | 9 + n  | $A \leftarrow A \lor (HL + B)$      | × |      |
|             |          | A, [HL + C]    | 2    | 8      | 9 + n  | $A \leftarrow A \lor (HL + C)$      | × |      |
|             | XOR      | A, #byte       | 2    | 4      | _      | A ← A <del>V</del> byte             | × |      |
|             |          | saddr, #byte   | 3    | 6      | 8      | (saddr) ← (saddr) <del>∀</del> byte | × |      |
|             |          | A, r Note 3    | 2    | 4      | -      | A ← A <del>∀</del> r                | × |      |
|             |          | r, A           | 2    | 4      | -      | r ← r <del>∀</del> A                | × |      |
|             |          | A, saddr       | 2    | 4      | 5      | $A \leftarrow A \forall$ (saddr)    | × |      |
|             |          | A, laddr16     | 3    | 8      | 9 + n  | A ← A → (addr16)                    | × |      |
|             |          | A, [HL]        | 1    | 4      | 5 + n  | A ← A ↔ (HL)                        | × |      |
|             |          | A, [HL + byte] | 2    | 8      | 9 + n  | A ← A <del>∀</del> (HL + byte)      | × |      |
|             | Þ        | A, [HL + B]    | 2    | 8      | 9 + n  | $A \leftarrow A \forall (HL + B)$   | × |      |
|             |          | A, [HL + C]    | 2    | 8      | 9 + n  | $A \leftarrow A \forall (HL + C)$   | × |      |

2. When an area other than the internal high-speed RAM area is accessed

3. Except r = A

Remarks 1. One clock of an instruction is equal to one CPU clock (fcpu) selected by processor clock control register (PCC).

- 2. The number of clocks shown is when the program is stored in the internal ROM area.
- 3. n indicates the number of wait states when the external memory extension area is read.

■ 6427525 0099697 609 **mm** 

237

| Instruction |          | Orward         | 2.44 | 6      | Clock      | Occupies                                                                                                         |   | Flag       | g  |
|-------------|----------|----------------|------|--------|------------|------------------------------------------------------------------------------------------------------------------|---|------------|----|
| Group       | Mnemonic | Operand        | Byte | Note 1 | Note 2     | Operation                                                                                                        | z | AC         | CY |
| 8-bit       | СМР      | A, #byte       | 2    | 4      | -          | A - byte                                                                                                         | × | ×          | ×  |
| operation   |          | saddr, #byte   | 3    | 6      | 8          | (saddr) - byte                                                                                                   | × | ×          | ×  |
|             |          | A, r Note 3    | 2    | 4      | -          | A-r                                                                                                              | × | ×          | ×  |
|             |          | r, A           | 2    | 4      | -          | r – A                                                                                                            | × | ×          | ×  |
|             |          | A, saddr       | 2    | 4      | 5          | A - (saddr)                                                                                                      | × | ×          | ×  |
|             |          | A, laddr16     | 3    | 8      | 9 + n      | A - (addr16)                                                                                                     | × | ×          | ×  |
|             |          | A, [HL]        | 1    | 4      | 5 + n      | A – (HL)                                                                                                         | × | ×          | ×  |
|             |          | A, [HL + byte] | 2    | 8      | 9 + n      | A - (HL + byte)                                                                                                  | × | ×          | ×  |
|             |          | A, [HL + B]    | 2    | 8      | 9 + n      | A - (HL + B)                                                                                                     | × | ×          | ×  |
|             |          | A, [HL + C]    | 2    | 8      | 9 + n      | A - (HL + C)                                                                                                     | × | ×          | ×  |
| 16-bit      | ADDW     | AX, #word      | 3    | 6      | -          | AX, CY $\leftarrow$ AX + word                                                                                    | × | ×          | ×  |
|             | SUBW     | AX, #word      | 3    | 6      | -          | AX, CY $\leftarrow$ AX – word                                                                                    | × | ×          | ×  |
|             | CMPW     | AX, #word      | 3    | 6      | -          | AX – word                                                                                                        | × | × ×<br>× × | ×  |
| · · · L     | MULU     | x              | 2    | 16     | -          | $AX \leftarrow A \times X$                                                                                       |   |            |    |
| divide      | DIVUW    | C              | 2    | 25     | -          | AX (quotient), C (remainder) ← AX + C                                                                            | Γ |            |    |
|             | INC      | r              | 1    | 2      | -          | r ← r + 1                                                                                                        | × | ×          |    |
| decrement   |          | saddr          | 2    | 4      | 6          | $(saddr) \leftarrow (saddr) + 1$                                                                                 | × | ×          |    |
|             | DEC      | r              | 1    | 2      | -          | r ← r − 1                                                                                                        | × | ×          |    |
|             |          | saddr          | 2    | 4      | 6          | (saddr) ← (saddr) ~ 1                                                                                            | × | ×          |    |
|             | INCW     | rp             | 1    | 4      |            | $rp \leftarrow rp + 1$                                                                                           |   |            |    |
|             | DECW     | rp             | 1    | 4      | -          | $rp \leftarrow rp - 1$                                                                                           |   |            |    |
| Rotate      | ROR      | A, 1           | 1    | 2      | -          | (CY, A <sub>7</sub> $\leftarrow$ A <sub>0</sub> , A <sub>m-1</sub> $\leftarrow$ A <sub>m</sub> ) $\times$ 1 time |   |            | ×  |
|             | ROL      | A, 1           | 1    | 2      | -          | (CY, $A_0 \leftarrow A_7$ , $A_{m+1} \leftarrow A_m$ ) × 1 time                                                  |   |            | ×  |
|             | RORC     | A, 1           | 1    | 2      | -          | $(CY \leftarrow A_0, A_7 \leftarrow CY, A_{m-1} \leftarrow A_m) \times 1$ time                                   |   |            | ×  |
| Į           | ROLC     | A, 1           | 1    | 2      | -          | $(CY \leftarrow A_7, A_0 \leftarrow CY, A_{m+1} \leftarrow A_m) \times 1$ time                                   |   |            | ×  |
|             | ROR4     | (HL)           | 2    | 10     | 12 + n + m | A3-0 ← (HL)3-0, (HL)7-4 ← A3-0,<br>(HL)3-0 ← (HL)7-4                                                             |   |            |    |
|             | ROL4     | [HL]           | 2    | 10     | 12 + n + m | $A_{3-0} \leftarrow (HL)_{7-4}, (HL)_{3-0} \leftarrow A_{3-0}, (HL)_{7-4} \leftarrow (HL)_{3-0}$                 |   |            |    |

2. When an area other than the internal high-speed RAM area is accessed

3. Except r = A

Remarks 1. One clock of an instruction is equal to one CPU clock (fcpu) selected by processor clock control register (PCC).

2. The number of clocks shown is when the program is stored in the internal ROM area.

3. n indicates the number of wait states when the external memory extension area is read.

4. m indicates the number of wait states when the external memory extension area is written.

238

6427525 0099698 545

| Instruction       | Mnemonic | Operand       | Byte | 6      | lock   | Occurrico                                    | 1 | Fla | 9  |
|-------------------|----------|---------------|------|--------|--------|----------------------------------------------|---|-----|----|
| Group             |          | Operand       | Бусе | Note 1 | Note 2 | Operation                                    | z | AC  | CY |
| BCD<br>adjustment | ADJBA    |               | 2    | 4      | -      | Decimal Adjust Accumulator after<br>Addition | × | ×   | ×  |
|                   | ADJBS    |               | 2    | 4      | -      | Decimal Adjust Accumulator after<br>Subtract | × | ×   | ×  |
| Bit               | MOV1     | CY, saddr.bit | 3    | 6      | 7      | CY ← (saddr.bit)                             |   |     | ×  |
| manipulation      |          | CY, sfr.bit   | 3    | -      | 7      | CY ← sfr.bit                                 |   |     | ×  |
|                   |          | CY, A.bit     | 2    | 4      | -      | CY ← A.bit                                   |   |     | ×  |
|                   |          | CY, PSW.bit   | 3    | -      | 7      | CY ← PSW.bit                                 |   |     | ×  |
|                   |          | CY, [HL].bit  | 2    | 6      | 7 + n  | CY ← (HL).bit                                |   |     | ×  |
|                   |          | saddr.bit, CY | 3    | 6      | 8      | (saddr.bit) ← CY                             |   |     |    |
|                   |          | sfr.bit, CY   | 3    | -      | 8      | sfr.bit ← CY                                 |   |     |    |
|                   |          | A.bit, CY     | 2    | 4      | -      | A.bit ← CY                                   |   |     |    |
|                   |          | PSW.bit, CY   | 3    | -      | 8      | PSW.bit ← CY                                 | × | ×   |    |
|                   |          | [HL].bit, CY  | 2    | 6      | 8+n+m  | (HL).bit ← CY                                |   |     |    |
|                   | AND1     | CY, saddr.bit | 3    | 6      | 7      | $CY \leftarrow CY \land (saddr.bit)$         |   |     | ×  |
|                   |          | CY, sfr.bit   | 3    | -      | 7      | $CY \leftarrow CY \land str.bit$             |   |     | ×  |
|                   |          | CY, A.bit     | 2    | 4      | -      | $CY \leftarrow CY \land A.bit$               |   |     | ×  |
|                   |          | CY, PSW.bit   | 3    | -      | 7      | CY ← CY ∧ PSW.bit                            |   |     | ×  |
|                   |          | CY, [HL].bit  | 2    | 6      | 7 + n  | $CY \leftarrow CY \land (HL).bit$            |   |     | ×  |
|                   | OR1      | CY, saddr.bit | 3    | 6      | 7      | CY ← CY∨(saddr.bit)                          |   |     | ×  |
|                   |          | CY, sfr.bit   | 3    | -      | 7      | CY ← CY∨sfr.bit                              |   |     | ×  |
|                   |          | CY, A.bit     | 2    | 4      |        | CY ← CY∨A.bit                                |   |     | ×  |
|                   |          | CY, PSW.bit   | 3    | -      | 7      | CY ← CY∨PSW.bit                              |   |     | ×  |
|                   |          | CY, [HL].bit  | 2    | 6      | 7 + n  | $CY \leftarrow CY \lor (HL).bit$             |   |     | ×  |
|                   | XOR1     | CY, saddr.bit | 3    | 6      | 7      | CY ← CY → (saddr.bit)                        |   |     | ×  |
|                   | •        | CY, sfr.bit   | 3    | -      | 7      | CY ← CY <del>∀</del> sfr.bit                 |   | -   | ×  |
| 1                 |          | CY, A.bit     | 2    | 4      | -      | CY ← CY <del>V</del> A.bit                   |   |     | ×  |
|                   |          | CY, PSW. bit  | 3    | -      | 7      | CY ← CY <del>∀</del> PSW.bit                 |   |     | ×  |
|                   |          | CY, [HL].bit  | 2    | 6      | 7 + n  | CY ← CY <del>∀</del> (HL).bit                |   |     | x  |

- 2. When an area other than the internal high-speed RAM area is accessed
- Remarks 1. One clock of an instruction is equal to one CPU clock (fcPu) selected by processor clock control register (PCC).
  - 2. The number of clocks shown is when the program is stored in the internal ROM area.
  - 3. n indicates the number of wait states when the external memory extension area is read.
  - 4. m indicates the number of wait states when the external memory extension area is written.

🔲 6427525 0099699 481 🖿

| Instruction  | Mnemonic   | Operand   | Bute | Clock  |        | Operation                                                                                                                                                                                              |   | Fla | 9  |
|--------------|------------|-----------|------|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-----|----|
| Group        | MILETHOURC | Operand   | Byte | Note 1 | Note 2 | Operation                                                                                                                                                                                              | z | AC  | CY |
| Bit          | SET1       | saddr.bit | 2    | 4      | 6      | (saddr.bit) ← 1                                                                                                                                                                                        |   |     |    |
| manipulation |            | sfr.bit   | 3    | -      | 8      | sfr.bit ← 1                                                                                                                                                                                            | Γ |     |    |
|              |            | A.bit     | 2    | 4      | -      | A.bit ← 1                                                                                                                                                                                              |   |     |    |
| •            |            | PSW.bit   | 2    | -      | 6      | PSW.bit ← 1                                                                                                                                                                                            | × | ×   | ×  |
|              |            | [HL].bit  | 2    | 6      | 8+n+m  | (HL).bit ← 1                                                                                                                                                                                           |   |     |    |
|              | CLR1       | saddr.bit | 2    | 4      | 6      | (saddr.bit) ← 0                                                                                                                                                                                        |   |     |    |
|              |            | sfr.bit   | 3    | -      | 8      | sfr.bit ← 0                                                                                                                                                                                            |   |     |    |
|              |            | A.bit     | 2    | 4      | -      | A.bit ← 0                                                                                                                                                                                              |   |     |    |
|              |            | PSW.bit   | 2    | -      | 6      | PSW.bit ← 0                                                                                                                                                                                            | × | ×   | ×  |
|              |            | [HL].bit  | 2    | 6      | 8+n+m  | (HL).bit ← 0                                                                                                                                                                                           |   |     |    |
|              | SET1       | CY        | 1    | 2      | -      | CY ← 1                                                                                                                                                                                                 |   |     | 1  |
|              | CLR1       | CY        | 1    | 2      | _      | CY ← 0                                                                                                                                                                                                 |   |     | 0  |
|              | NOT1       | CY        | 1    | 2      | -      | $CY \leftarrow \overline{CY}$                                                                                                                                                                          |   |     | ×  |
| Call/return  | CALL       | laddr16   | 3    | 7      | -      | $(SP - 1) \leftarrow (PC + 3)H$ , $(SP - 2) \leftarrow (PC + 3)L$ ,<br>PC $\leftarrow$ addr16, SP $\leftarrow$ SP - 2                                                                                  |   |     |    |
|              | CALLF      | laddr11   | 2    | 5      | -      | $(SP - 1) \leftarrow (PC + 2)H, (SP - 2) \leftarrow (PC + 2)L,$<br>$PC_{15-11} \leftarrow 00001, PC_{10-0} \leftarrow addr11,$<br>$SP \leftarrow SP - 2$                                               |   |     |    |
|              | CALLT      | [addr5]   | 1    | 6      |        | $(SP - 1) \leftarrow (PC + 1)H, (SP - 2) \leftarrow (PC + 1)L,$<br>$PCH \leftarrow (00000000, addr5 + 1),$<br>$PCL \leftarrow (00000000, addr5),$<br>$SP \leftarrow SP - 2$                            |   |     |    |
|              | BRK        |           | 1    | 6      |        | $(SP - 1) \leftarrow PSW$ , $(SP - 2) \leftarrow (PC + 1)H$ ,<br>$(SP - 3) \leftarrow (PC + 1)L$ , $PCH \leftarrow (003FH)$ ,<br>$PCL \leftarrow (003EH)$ , $SP \leftarrow SP - 3$ , $IE \leftarrow 0$ |   |     |    |
|              | RET        |           | 1    | 6      | 1      | PCH ← (SP + 1), PCL ← (SP),<br>SP ← SP + 2                                                                                                                                                             |   |     |    |
|              | RETI       |           | 1    | 6      |        | PCH ← (SP + 1), PCL ← (SP),<br>PSW ← (SP + 2), SP ← SP + 3,<br>NMIS ← 0                                                                                                                                | R | R   | R  |
|              | RETB       |           | 1    | 6      |        | $PCH \leftarrow (SP + 1), PCL \leftarrow (SP),$<br>$PSW \leftarrow (SP + 2), SP \leftarrow SP + 3$                                                                                                     | R | R   | R  |

2. When an area other than the internal high-speed RAM area is accessed

- Remarks 1. One clock of an instruction is equal to one CPU clock (fcpu) selected by processor clock control register (PCC).
  - 2. The number of clocks shown is when the program is stored in the internal ROM area.
  - 3. n indicates the number of wait states when the external memory extension area is read.
  - 4. m indicates the number of wait states when the external memory extension area is written.

240

🔲 6427525 0099700 T23 📰

| Instruction   | Mnemonic  | Operand            | Dista | C      | lock   | Operation                                                                     |        | Flag | 3       |
|---------------|-----------|--------------------|-------|--------|--------|-------------------------------------------------------------------------------|--------|------|---------|
| Group         | Minemonic | Operand            | Byte  | Note 1 | Note 2 | Operation                                                                     | z      | AC   | CY      |
| Stack         | PUSH      | PSW                | 1     | 2      | -      | (SP - 1) ← PSW, SP ← SP - 1                                                   |        |      | <u></u> |
| manipulation  |           | q                  | 1     | 4      | -      | $(SP - 1) \leftarrow rpH, (SP - 2) \leftarrow rpL,$<br>$SP \leftarrow SP - 2$ |        |      |         |
|               | POP       | PSW                | 1     | 2      | -      | PSW ← (SP), SP ← SP + 1                                                       | R      | R    | R       |
|               |           | ſ₽                 | 1     | 4      | -      | $rpH \leftarrow (SP + 1), rpL \leftarrow (SP),$<br>SP ← SP + 2                |        |      |         |
|               | MOVW      | SP, #word          | 4     | -      | 10     | SP ← word                                                                     |        |      |         |
|               |           | SP, AX             | 2     | -      | 8      | SP ← AX                                                                       |        |      |         |
|               |           | AX, SP             | 2     | -      | 8      | AX ← SP                                                                       |        |      |         |
| Unconditional | BR        | laddr16            | 3     | 6      |        | PC ← addr16                                                                   | $\top$ |      |         |
| branch .      |           | Saddr16            | 2     | 6      | -      | PC ← PC + 2 + jdisp8                                                          | 1      |      |         |
|               |           | AX                 | 2     | 8      | _      | $PCH \leftarrow A, PCL \leftarrow X$                                          |        |      | i       |
| Conditional   | BC        | Saddr16            | 2     | 6      | -      | PC ← PC + 2 + jdisp8 if CY = 1                                                |        |      |         |
| branch        | BNC       | Saddr16            | 2     | 6      | -      | $PC \leftarrow PC + 2 + jdisp8 \text{ if } CY = 0$                            |        |      |         |
|               | BZ        | Saddr16            | 2     | 6      | -      | $PC \leftarrow PC + 2 + jdisp8 \text{ if } Z = 1$                             |        |      |         |
|               | BNZ       | Saddr16            | 2     | 6      | _      | $PC \leftarrow PC + 2 + jdisp8 \text{ if } Z = 0$                             |        |      |         |
|               | вт        | saddr.bit, Saddr16 | 3     | 8      | 9      | PC ← PC + 3 + jdisp8 if (saddr.bit) = 1                                       |        |      |         |
|               |           | sfr.bit, \$addr16  | 4     | -      | 11     | $PC \leftarrow PC + 4 + jdisp8$ if str.bit = 1                                |        |      |         |
|               |           | A.bit, \$addr16    | 3     | 8      | -      | $PC \leftarrow PC + 3 + jdisp8$ if A_bit = 1                                  |        | -    |         |
|               |           | PSW.bit, \$addr16  | 3     | _      | 9      | PC ← PC + 3 + jdisp8 if PSW.bit = 1                                           |        |      |         |
|               |           | [HL].bit, Saddr16  | 3     | 10     | 11 + n | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 1                               |        |      |         |
| BF            | BF        | saddr.bit, Saddr16 | 4     | 10     | 11     | $PC \leftarrow PC + 4 + jdisp8 \text{ if } (saddr.bit) = 0$                   | 1      |      |         |
|               |           | sfr.bit, \$addr16  | 4     | -      | 11     | $PC \leftarrow PC + 4 + jdisp8 \text{ if str.bit} = 0$                        | 1      |      |         |
|               |           | A.bit, Saddr16     | 3     | 8      | -      | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 0                                  |        |      |         |
|               |           | PSW.bit, Saddr16   | 4     | -      | 11     | $PC \leftarrow PC + 4 + jdisp8$ if PSW. bit = 0                               |        |      |         |
|               |           | [HL].bit, \$addr16 | 3     | 10     | 11 + n | $PC \leftarrow PC + 3 + jdisp8$ if (HL).bit = 0                               | T      |      |         |

2. When an area other than the internal high-speed RAM area is accessed

Remarks 1. One clock of an instruction is equal to one CPU clock (fcpu) selected by processor clock control register (PCC).

2. The number of clocks shown is when the program is stored in the internal ROM area.

3. n indicates the number of wait states when the external memory extension area is read.

. \_\_\_\_\_ .

🔲 6427525 009970l 96T 🖿

| Instruction        |          | 0                   | Biste | Clock  |            | Operation                                                                                     | Flag |    | J  |
|--------------------|----------|---------------------|-------|--------|------------|-----------------------------------------------------------------------------------------------|------|----|----|
| Group              | Mnemonic | Operand             | Byte  | Note 1 | Note 2     |                                                                                               | z    | AC | CY |
| Conditional branch | BTCLR    | saddr.bit, \$addr16 | 4     | 10     | 12         | $PC \leftarrow PC + 4 + jdisp8$ if (saddr.bit) = 1<br>then reset (saddr.bit)                  |      |    |    |
|                    |          | sfr.bit, \$addr16   | 4     | -      | 12         | $PC \leftarrow PC + 4 + jdisp8$ if sfr.bit = 1<br>then reset sfr.bit                          |      |    |    |
|                    |          | A.bit, \$addr16     | 3     | 8      | -          | $PC \leftarrow PC + 3 + jdisp8$ if A.bit = 1<br>then reset A.bit                              |      |    |    |
|                    |          | PSW.bit, \$addr16   | 4     | -      | 12         | $PC \leftarrow PC + 4 + jdisp8 \text{ if } PSW.bit = 1$<br>then reset PSW.bit                 | ×    | ×  | ×  |
|                    |          | [HL].bit, \$addr16  | 3     | 10     | 12 + n + m | $PC \leftarrow PC + 3 + jdisp8 \text{ if (HL).bit} = 1$<br>then reset (HL).bit                |      |    |    |
|                    | DBNZ     | B, \$addr16         | 2     | 6      | -          | B ← B – 1, then<br>PC ← PC + 2 + jdisp8 if B ≠ 0                                              |      |    |    |
|                    |          | C, Saddr16          | 2     | 6      | -          | C ← C −1, then<br>PC ← PC + 2 + jdisp8 if C ≠ 0                                               |      |    |    |
|                    |          | saddr, \$addr16     | 3     | 8      | 10         | (saddr) $\leftarrow$ (saddr) – 1, then<br>PC $\leftarrow$ PC + 3 + jdisp8 if (saddr) $\neq$ 0 |      |    |    |
| CPU                | SEL      | RBn                 | 2     | 4      | -          | RBS1, 0 ← n                                                                                   |      |    |    |
| control            | NOP      |                     | 1     | 2      | -          | No operation                                                                                  |      |    |    |
|                    | El       |                     | 2     | -      | 6          | IE ← 1 (Enable interrupt)                                                                     | Τ    |    |    |
|                    | DI       |                     | 2     | -      | 6          | IE ← 0 (Disable interrupt)                                                                    |      |    |    |
|                    | HALT     |                     | 2     | 6      | -          | Set HALT mode                                                                                 |      |    |    |
|                    | STOP     |                     | 2     | 6      | _          | Set STOP mode                                                                                 |      |    |    |

- Notes 1. When the internal high-speed RAM area is accessed or when an instruction that does not access data is executed
  - 2. When an area other than the internal high-speed RAM area is accessed
- **Remarks 1.** One clock of an instruction is equal to one CPU clock (fcPu) selected by processor clock control register (PCC).
  - 2. The number of clocks shown is when the program is stored in the internal ROM area.
  - 3. n indicates the number of wait states when the external memory extension area is read.
  - 4. m indicates the number of wait states when the external memory extension area is written.

# 18.3 Instruction List by Addressing

(1) 8-bit instructions

MOV, XCH, ADD, ADDC, SUB, SUBC, AND, OR, XOR, CMP, MULU, DIVUW, INC, DEC, ROR, ROL, RORC, ROLC, ROR4, ROL4, PUSH, POP, DBNZ

242

#### 🖬 6427525 0099702 BT6 📰

| 2nd Operand                         |                                                              |                                                              |                                                                     |            |       |                                                                     |     |            |      | [HL + byte]                                                         |         |                            |              |
|-------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------|------------|-------|---------------------------------------------------------------------|-----|------------|------|---------------------------------------------------------------------|---------|----------------------------|--------------|
| 1st Operand                         | #byte                                                        | A                                                            | <sub>r</sub> Note                                                   | sfr        | saddr | laddr16                                                             | PSW | [DE]       | [HL] | [HL + B]<br>[HL + C]                                                | Saddr16 | 1                          | None         |
| A                                   | ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP        |                                                              | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV<br>XCH | SUB   | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV | MOV<br>XCH | SUB  | MOV<br>XCH<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |         | ROR<br>ROL<br>RORC<br>ROLC |              |
| r                                   | MOV                                                          | MOV<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP |                                                                     |            |       |                                                                     |     |            |      |                                                                     |         |                            | INC<br>DEC   |
| B, C                                |                                                              |                                                              |                                                                     |            |       |                                                                     |     |            |      |                                                                     | DBNZ    |                            |              |
| sfr                                 | MOV                                                          | MOV                                                          |                                                                     |            |       |                                                                     |     |            |      |                                                                     |         |                            |              |
| saddr                               | MOV<br>ADD<br>ADDC<br>SUB<br>SUBC<br>AND<br>OR<br>XOR<br>CMP | MOV                                                          |                                                                     |            |       |                                                                     |     |            |      |                                                                     | DBNZ    |                            | INC<br>DEC   |
| laddr16                             |                                                              | MOV                                                          |                                                                     |            |       |                                                                     |     |            |      |                                                                     |         |                            |              |
| PSW                                 | MOV                                                          | MOV                                                          |                                                                     |            |       |                                                                     |     |            |      |                                                                     |         |                            | PUSH<br>POP  |
| [DE]                                |                                                              | MOV                                                          |                                                                     |            |       |                                                                     |     |            |      |                                                                     |         |                            |              |
| [HL]                                |                                                              | MOV                                                          |                                                                     |            |       |                                                                     |     |            |      |                                                                     |         |                            | ROR4<br>ROL4 |
| [HL + byte]<br>[HL + B]<br>[HL + C] |                                                              | MOV                                                          |                                                                     |            |       |                                                                     |     |            |      |                                                                     |         |                            |              |
| x                                   |                                                              |                                                              |                                                                     |            |       |                                                                     |     |            |      |                                                                     |         |                            | MULU         |
| С                                   |                                                              |                                                              |                                                                     |            |       |                                                                     |     |            |      |                                                                     |         |                            | שטעום        |

Note Except for r = A

-----

🖿 6427525 0099703 732 🖿

\_\_\_\_\_

#### (2) 16-bit instructions

MOVW, XCHW, ADDW, SUBW, CMPW, PUSH, POP, INCW, DECW

| 2nd Operand<br>1st Operand | #word                | AX       | rp <sup>Note</sup> | sfrp | saddrp | !addr16 | SP   | None                        |
|----------------------------|----------------------|----------|--------------------|------|--------|---------|------|-----------------------------|
| AX                         | ADDW<br>SUBW<br>CMPW |          | MOVW<br>XCHW       | MOVW | MOVW   | MOVW    | MOVW |                             |
| rp                         | MOVW                 | MOVWNote |                    |      |        |         |      | INCW<br>DECW<br>PUSH<br>POP |
| sfrp                       | MOVW                 | MOVW     |                    |      |        |         |      |                             |
| saddrp                     | MOVW                 | MOVW     |                    |      |        |         |      |                             |
| laddr16                    |                      | MOVW     |                    |      |        |         |      |                             |
| SP                         | MOVW                 | MOVW     |                    |      |        |         |      |                             |

Note Only when rp = BC, DE, HL

#### (3) Bit manipulation instructions

MOV1, AND1, OR1, XOR1, SET1, CLR1, NOT1, BT, BF, BTCLR

| 2nd Operand<br>1st Operand | A.bit                       | sfr.bit                     | saddr.bit                   | PSW.bit                     | (HL].bit                    | CY   | \$addr16          | None                 |
|----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|------|-------------------|----------------------|
| A.bit                      |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| sfr.bit                    |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| saddr.bit                  |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| PSW.bit                    |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| (HL].bit                   |                             |                             |                             |                             |                             | MOV1 | BT<br>BF<br>BTCLR | SET1<br>CLR1         |
| сү                         | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 | MOV1<br>AND1<br>OR1<br>XOR1 |      |                   | SET1<br>CLR1<br>NOT1 |

244

# 🔲 6427525 0099704 679 📰

## (4) Call/branch instructions

CALL, CALLF, CALLT, BR, BC, BNC, BZ, BNZ, BT, BF, BTCLR, DBNZ

| 2nd Operand<br>1st Operand | AX | laddr16    | laddr11 | [addr5] | \$addr16                     |
|----------------------------|----|------------|---------|---------|------------------------------|
| Basic instruction          | BR | CALL<br>BR | CALLF   | CALLT   | BR<br>BC<br>BNC<br>BZ<br>BNZ |
| Compound<br>instruction    |    |            |         |         | BT<br>BF<br>BTCLR<br>DBNZ    |

#### (5) Other instructions

ADJBA, ADJBS, BRK, RET, RETI, RETB, SEL, NOP, EI, DI, HALT, STOP

# 🔳 6427525 0099705 505 🖿

# PAGE(S) INTENTIONALLY BLANK

246

| 64275250099706441 🎟

Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### APPENDIX A DEVELOPMENT TOOLS

The following development tools are available for development of systems using the  $\mu$ PD780924 and 780964 subseries.

Figure A-1 shows development tools.

6427525 0099707 388

-----

-----





Powered by ICminer.com Electronic-Library Service CopyRight 2003

| RA78K/0<br>Assembler package                 | Program that converts program written in mnemonic into object codes that<br>can be executed by microcontroller.<br>In addition, automatic functions to generate symbol table and optimize<br>branch instructions are also provided.<br>Used in combination with optional device file (DF780964). |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CC78K/0<br>C compiler package                | Part number: μSxxxxRA78K0         Program that converts program written in C language into object codes that can be executed by microcontroller.         Used in combination with optional assembler package (RA78K/0) and device file (DF780964).                                               |
| DF780964 <sup>Note</sup> 1, 2<br>Device file | Part number: μSxxxCC78K0<br>File containing information peculiar to the device.<br>Used in combination with optional RA78K/0, CC78K/0, SM78K0, or ID78K0.                                                                                                                                        |
|                                              | Part number: μS∞∞xDF780964                                                                                                                                                                                                                                                                       |
| CC78K/0-L<br>C library source file           | Source program of functions for generating object library included in C compiler package (CC78K/0).<br>Necessary for changing object library included in CC78K/0 according to customer's specifications.                                                                                         |
|                                              | Part number: μSxxxCC78K0-L                                                                                                                                                                                                                                                                       |

## A.1 Language Processing Software

Notes 1. DF780964 is a common file that can be used with RA78K/0, CC78K/0, SM78K0, and ID78K0. 2. Under development

Remark  $\rightarrow \infty \infty$  in part number differs depending on the host machine and OS used.

μSxxxRA78K0 μSxxxCC78K0 μSxxxDF780964 μSxxxCC78K0-L

| xxxxx | Host Machine                    | OS                                        | Supply Media                |  |
|-------|---------------------------------|-------------------------------------------|-----------------------------|--|
| 5A13  | PC-9800 Series                  | MS-DOSTM                                  | 3.5" 2HD                    |  |
| 5A10  |                                 | (Ver.3.30 to<br>Ver.6.2 <sup>Note</sup> ) | 5" 2HD                      |  |
| 7B13  | IBM PC/AT <sup>TM</sup> and     | Refer to A.4                              | 3.5" 2HC                    |  |
| 7B10  | compatible machines             |                                           | 5" 2HC                      |  |
| 3H15  | HP9000 Series 300 <sup>TM</sup> | HP-UX <sup>TM</sup> (rel.7.05B)           | Cartridge tape<br>(QIC-24)  |  |
| 3P16  | HP9000 Series 700 <sup>TM</sup> | HP-UX (rel.9.01)                          | Digital audio tape<br>(DAT) |  |
| 3K15  | SPARCstation <sup>TM</sup>      | SunOS <sup>TM</sup> (rel.4.1.1)           | Cartridge tape              |  |
| 3M15  | EWS4800 Series (RISC)           | EWS-UX/V (rel.4.0)                        | (QIC-24)                    |  |

**Note** Although MS-DOS Ver. 5.0 and above have a task swap function, this function cannot be used with this software.

■ 6427525 CC997C9 15C 📖

249

| Flashpro                                                                    | Flash writer dedicated to microcontroller with flash memory.                                                                                                                                                                            |  |  |
|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Flash writer This is a product of Naitou Densei Machidaseisakusho Co., Ltd. |                                                                                                                                                                                                                                         |  |  |
| FA-64CW <sup>Note</sup><br>Flash memory writing adapter                     | Flash memory writing adapter for the $\mu$ PD780924 and 780964 subseries and is connected to the Flashpro. This adapter is for a 64-pin plastic shrink DIP (CW type).<br>This is a product of Naitou Densei Machidaseisakusho Co., Ltd. |  |  |
| FA-64GC <sup>Note</sup><br>Flash memory writing adapter                     | Flash memory writing adapter for the $\mu$ PD780924 and 780964 subseries and is connected to the Flashpro. This adapter is for a 64-pin plastic QFP (GC-AB8 type). This is a product of Naitou Densei Machidaseisakusho Co., Ltd.       |  |  |

# A.2 Flash Memory Writing Tools

Note Under development

250

🖿 6427525 0099710 972 🎟

# A.3 Debugging Tools

# A.3.1 Hardware

| IE-780000-SI<br>in-circuit emu        | -                                | This in-circuit emulator is used to debug hardware and software when an application system using the 78K/0 series is developed. It supports the integrated debugger (ID78K0). This emulator is used in combination with an emulation probe and an interface adapter that connects the emulator with the host machine. For connection with EWS, 10Base-T and 10Base-5 are supported as Ethernet <sup>TM</sup> . |  |  |  |
|---------------------------------------|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| IE-70000-98-<br>interface ada         |                                  | Adapter necessary when using the PC-9800 series (except the notebook type) as the host machine of the IE-780000-SL.                                                                                                                                                                                                                                                                                            |  |  |  |
| IE-70000-98N-IF<br>interface adapter  |                                  | Adapter and cable necessary when using the notebook type PC-9800 series<br>as the host machine of the IE-780000-SL.<br>This adapter cannot be connected to a notebook type computer unless<br>the connector of the expansion bus is of 110-pin type.                                                                                                                                                           |  |  |  |
| IE-70000-PC-IF-B<br>interface adapter |                                  | Adapter necessary when using IBM PC/AT and compatible machines as the host machine of the IE-780000-SL.                                                                                                                                                                                                                                                                                                        |  |  |  |
| IE-78K0-SL-E<br>CPU core bo           |                                  | This board is used in combination with an in-circuit emulator, I/O board, an probe board, to emulate the CPU of the 78K/O series.                                                                                                                                                                                                                                                                              |  |  |  |
| IE-780964-SI<br>probe board           | EM1 <sup>Note</sup>              | This board is used to set mask options and convert pin connection.                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| EP-64CW-SL<br>emulation pro           | -                                | This is a probe to connect an in-circuit emulator and target system.<br>It is for a 64-pin plastic shrink DIP (CW type).                                                                                                                                                                                                                                                                                       |  |  |  |
| EP-64GC-SL<br>emulation pro           |                                  | This is a probe to connect an in-circuit emulator and target system.<br>It is for 64-pin plastic QFP (GC-AB8 type).<br>One 64-pin conversion socket, TQPACK064SA, which facilitates develop-<br>ment of the target system is supplied as an accessory.                                                                                                                                                         |  |  |  |
|                                       | TQPACK064SA<br>conversion socket | This conversion socket connects the board of the target system created<br>for mounting 64-pin plastic QFP (GC-AB8 type) and the EP-64GC-SL.<br>The TQPACK064SA is made by TOKYO ELETECH CORPORATION (Tokyo<br>(03)5295-1661). Contact an authorized NEC distributor to purchase this product.                                                                                                                  |  |  |  |

Note Under development

🔲 6427525 0099711 809 📰

- --

#### A.3.2 Software (1/2)

| SM78K0           | This simulator simulates the operation of the target system on the host        |
|------------------|--------------------------------------------------------------------------------|
| system simulator | machine and is used to debug the target system at C source level or            |
|                  | assembler level.                                                               |
|                  | The SM78K0 operates in Windows <sup>TM</sup> .                                 |
|                  | By using the SM78K0, the logic and performance of the application can be       |
|                  | verified independently of hardware development even if an in-circuit emu-      |
|                  | lator is not used, so that the development efficiency can be enhanced and      |
|                  | software quality can be improved.                                              |
|                  | This simulator is used in combination with an optional device file (DF780964). |
|                  | Part number: µSxxxSM78K0                                                       |

Remark xxxx in the part number differs depending on the host machine and OS used.

# μS<u>xxxx</u>SM78K0

| ×××× | Host Machine                | OS                               | Supply Media |
|------|-----------------------------|----------------------------------|--------------|
| AA13 | PC-9800 series              | MS-DOS (Ver.3.30 to Ver.6.2Note) | 3.5" 2HD     |
| AA10 |                             | Windows (Ver.3.0 to Ver.3.1)     | 5" 2HD       |
| AB13 | IBM PC/AT and compatible    | Refer to A.4.                    | 3.5" 2HC     |
| AB10 | machines (Japanese Windows) |                                  | 5" 2HC       |
| BB13 | IBM PC/AT and compatible    |                                  | 3.5" 2HC     |
| BB10 | machines (English Windows)  |                                  | 5" 2HC       |

**Note** Although MS-DOS Ver.5.0 and above have a task swap function, this function cannot be used with this software.

252

🗖 6427525 0099712 745 🛤

#### A.3.2 Software (2/2)

μSxxxID78K0

| ID78K0                                       | This is a control program that is used to debug the 78K/0 series.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| integrated debugger                          | It uses Windows on a personal computer and OSF/Motif <sup>TM</sup> on EWS as a graphical user interface, and has the appearance and operability conform-<br>ing to these interfaces. Moreover, debugging functions supporting C language are reinforced, and the trace result can be displayed in C language level by using a window integrating function that associates the source program, disassemble display, and memory display with the trace result. In addition, it can enhance the debugging efficiency of a program using a real-<br>time OS by incorporating function expansion modules such as a task debugger and system performance analyzer.<br>This debugger is used in combination with an optional device file (DF780964). |
|                                              | Part number: µS∞∞xID78K0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| DF780964 <sup>Note</sup> 1, 2<br>device file | File storing information peculiar to the device.<br>Used in combination with optional RA78K/0, CC78K/0, SM78K0, or ID78K0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                              | Part number: µSxxxDF780964                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Notes 1. The DF780964 is a common file that can be used with RA78K/0, CC78K/0, SM78K0, and ID78K0. 2. Under development

Remark xxxx in the part number differs depending on the host machine and OS used.

| <u>xxxx</u>  | Host Machine                | OS                               | Supply Media               |
|--------------|-----------------------------|----------------------------------|----------------------------|
| AA13         | PC-9800 series              | MS-DOS (Ver.3.30 to Ver.6.2Note) | 3.5" 2HD                   |
| AA10         |                             | Windows (Ver.3.1)                | 5" 2HD                     |
| AB13         | IBM PC/AT and compatible    | Refer to A.4.                    | 3.5" 2HC                   |
| AB10         | machines (Japanese Windows) |                                  | 5" 2HC                     |
| BB13         | IBM PC/AT and compatible    |                                  | 3.5" 2HC                   |
| BB10         | machines (English Windows)  |                                  | 5" 2HC                     |
| 3P16         | HP9000 Series 700           | HP-UX (rel.9.01)                 | Digital audio tap<br>(DAT) |
| <b>3</b> K15 | SPARCstation                | SunOS (rel.4.1.1)                | Cartridge tape<br>(QIC-24) |
| 3K13         |                             |                                  | 3.5" 2HC                   |
| 3R16         | NEWS <sup>™</sup> (RISC)    | NEWS-OS <sup>TM</sup> (6.1x)     | 1/4" CGMT                  |
| 3R13         |                             |                                  | 3.5" 2HC                   |
| 3M15         | EWS4800 series (RISC)       | EWS-UX/V (rel.4.0)               | Cartridge tape<br>(QIC-24) |

Note Although MS-DOS Ver.5.0 and above have a task swap function, this function cannot be used with this software.

🔲 6427525 0099713 681 🔳

253

--- ---

# A.4 OS for IBM PC

The following OSs for the IBM PC are supported.

To operate SM78K0, ID78K0, and FE9200 (refer to B.2 Fuzzy Inference Development Support System), Windows (Ver. 3.0 to Ver. 3.1) is necessary.

| OS                   | Version                                          |
|----------------------|--------------------------------------------------|
| PC DOS <sup>TM</sup> | Ver. 5.02 to Ver. 6.3                            |
|                      | J6.1/V <sup>Note</sup> to J6.3/V <sup>Note</sup> |
| IBM DOSTM            | J5.02/V <sup>Note</sup>                          |
| MS-DOS               | Ver. 5.0 to Ver. 6.22                            |
|                      | 5.0/V <sup>Note</sup> to 6.2/V <sup>Note</sup>   |

Note Only English mode is supported.

Caution Although Ver. 5.0 and above have a task swap function, this function cannot be used with this software.

#### 🖬 6427525 0099714 518 **ES**

254

# A.5 Changing Other In-Circuit Emulators to In-Circuit Emulator for 78K/0 Series

If you have an in-circuit emulator for the 78K series or 75X/XL series, your in-circuit emulator can be upgraded to be equivalent to the in-circuit emulator IE-780000-SL for the 78K/0 series by exchanging the break board with the IE-78000-R-BK and connecting interface board IE-78000-R-IF. CPU core board IE-78K0-SL-EM is not necessary.

| Series Name    | Your In-Circuit Emulator                                                                | Necessary Board |
|----------------|-----------------------------------------------------------------------------------------|-----------------|
| 78K/0 series   | IE-78000-R, IE-78000-R-A                                                                | IE-78000-R-BK   |
| 75X/XL series  | IE-75000-R <sup>Note</sup> , IE-75001-R                                                 | IE-78000-R-IF   |
| 78K/I series   | IE-78130-R, IE-78140-R                                                                  |                 |
| 78K/II series  | IE-78230-R <sup>Note</sup> , IE-78230-R-A,<br>IE-78240-R <sup>Note</sup> , IE-78240-R-A |                 |
| 78K/III series | IE-78320-R <sup>Note</sup> , IE-78327-R,<br>IE-78330-R, IE-78350-R                      |                 |
| 78K/IV series  | IE-784000-R                                                                             |                 |

| Table A-1. | Changing O | Other In-Circuit | Emulators t | to IE-780000-SL |
|------------|------------|------------------|-------------|-----------------|
|------------|------------|------------------|-------------|-----------------|

Note Maintenance parts

[MEMO]

# PAGE(S) INTENTIONALLY BLANK

256

6427525 0099716 390 📟

Powered by ICminer.com Electronic-Library Service CopyRight 2003

# APPENDIX B EMBEDDED SOFTWARE

For efficient program development and maintenance of  $\mu$ PD780924 and 780964 subseries, the following embedded softwares are available.

.

🖬 6427525 0099717 227 📰

\_...

-----

-----

# B.1 Real-Time OS (1/2)

| RX78K/0      | RX78K/0 is real-time OS conforming to µITRON specifications.                                   |  |  |
|--------------|------------------------------------------------------------------------------------------------|--|--|
| Real-time OS | Fool (configurator) that creates nucleus of RX78K/0 and plural information tables is supplied. |  |  |
|              | Used in combination with an optional assembler package (RA78K/0) and device file (DF78096      |  |  |
| •            | Part number: μS∞∞xRX78013-ΔΔΔΔ                                                                 |  |  |

Caution When purchasing the RX78K/0, fill an application form and conclude the contract for use permission in advance.

**Remark**  $\infty \propto$  and  $\Delta \Delta \Delta \Delta$  in the part number differ depending on the host machine and OS used.

# *μ* <u>S∞∞∞</u>RX78013<u>-∆∆∆∆</u>

| <u> </u> |      | Product outline                      | Upper limit of quantity for mass production |  |
|----------|------|--------------------------------------|---------------------------------------------|--|
| Ī        | 001  | Evaluation object                    | Do not use for mass-produced product.       |  |
| 10       | 100K | Object for mass-<br>produced product | 0.1 million units                           |  |
| Ī        | 001M |                                      | 1 million units                             |  |
| Ī        | 010M | F                                    | 10 million units                            |  |
| Γ        | S01  | Source program                       | Source program for mass-produced object     |  |

| ×××× | Host machine             | OS                                                  | Supply media                |  |
|------|--------------------------|-----------------------------------------------------|-----------------------------|--|
| 5A13 | <b>DO 0000</b>           | MS-DOS<br>(Ver.3.30 to<br>Ver.6.2 <sup>Note</sup> ) | 3.5° 2HD                    |  |
| 5A10 | PC-9800 series           |                                                     | 5" 2HD                      |  |
| 7B13 | IBM PC/AT and            |                                                     | 3.5* 2HC                    |  |
| 7B10 | compatible machines      | Refer to A.4                                        | 5* 2HC                      |  |
| 3H15 | HP9000 series 300        | HP-UX (rel.7.05B)                                   | Cartridge tape<br>(QIC-24)  |  |
| 3P16 | HP9000 series 700        | HP-UX (rel.9.01)                                    | Digital audio tape<br>(DAT) |  |
| 3K15 | SPARCstation             | SunOS (rel.4.1.1)                                   | Cartridge tape              |  |
| 3M15 | EWS4800 series<br>(RISC) | EWS-UX/V (rel.4.0)                                  | (QIC-24)                    |  |

**Note** Although MS-DOS Ver. 5.0 and above have a task swap function, this function cannot be used with this software.

258

| 6427525 0099718 163 🎟

# B.1 Real-Time OS (2/2)

| MX78K0 μITRON-specification subset OS. Nucleus of MX78K0 is supplied. |                                                                                                                                                                                |  |  |
|-----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| os                                                                    | This OS performs task management, event management, and time management. It controls the task execution sequence for task management and selects the task to be executed next. |  |  |
|                                                                       | Part number: µS∞∞MX78K0-∆∆∆                                                                                                                                                    |  |  |

**Remark**  $\infty \infty$  and  $\Delta \Delta \Delta$  in the part number differ depending on the host machine and OS used.

# $\mu S_{\infty} MX78K0-\Delta \Delta \Delta$

| $\Delta\Delta\Delta$ | Product outline                      | Note                                                                         |
|----------------------|--------------------------------------|------------------------------------------------------------------------------|
| 001                  | Evaluation object                    | Use for trial product                                                        |
| ××                   | Object for mass-<br>produced product | Use for mass-produced product                                                |
| S01                  | Source program                       | Can be purchased only when object for mass-<br>produced product is purchased |

| ×××× | Host machine             | os                                        | Supply media                |  |
|------|--------------------------|-------------------------------------------|-----------------------------|--|
| 5A13 |                          | MS-DOS                                    | 3.5" 2HD                    |  |
| 5A10 | PC-9800 series           | (Ver.3.30 to<br>Ver.6.2 <sup>Note</sup> ) | 5" 2HD                      |  |
| 7B13 | IBM PC/AT and            |                                           | 3.5* 2HC                    |  |
| 7B10 | compatible machines      | Refer to A.4                              | 5" 2HC                      |  |
| 3H15 | HP9000 series 300        | HP-UX (rel.7.05B)                         | Cartridge tape<br>(QIC-24)  |  |
| 3P16 | HP9000 series 700        | HP-UX (rel.9.01)                          | Digital audio tape<br>(DAT) |  |
| 3K15 | SPARCstation             | SunOS (rel.4.1.1)                         | Cartridge tape              |  |
| 3M15 | EWS4800 series<br>(RISC) | EWS-UX/V (rel.4.0)                        | (Q!C-24)                    |  |

Note Although MS-DOS Ver. 5.0 and above have a task swap function, this function cannot be used with this software.

# 🔲 6427525 0099719 OTT 🔳

| <b>B.2</b> | Fuzzy | Inference | Development | Support | System |
|------------|-------|-----------|-------------|---------|--------|
|------------|-------|-----------|-------------|---------|--------|

| FE9000/FE9200<br>Fuzzy knowledge data creation<br>tool | Program that supports input, edit, and evaluation (simulation) of fuzzy knowledge data (fuzzy rule and membership function). FE9200 works on Windows. |
|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                        | Part number: $\mu$ SxxxFE9000 (PC-9800 series)<br>$\mu$ SxxxFE9200 (IBM PC/AT and compatible machines)                                                |
| FT9080/FT9085<br>Translator                            | Program that translates fuzzy knowledge data obtained by using fuzzy knowl-<br>edge data creation tool into assembler source program for RA78K/0.     |
|                                                        | Part number: $\mu$ SxxxFT9080 (PC-9800 series)<br>$\mu$ SxxxFT9085 (IBM PC/AT and compatible machines)                                                |
| FI78K0<br>Fuzzy inference module                       | Program that executes fuzzy inference. Executes fuzzy inference when linked with fuzzy knowledge data translated by translator.                       |
|                                                        | Part number: $\mu$ SxxxFI78K0 (PC-9800 series, IBM PC/AT and compatible machines)                                                                     |
| FD78K0<br>Fuzzy inference debugger                     | Support software for evaluation and adjustment of fuzzy knowledge data by using in-circuit emulator and at hardware level.                            |
|                                                        | Part number: $\mu$ SxxxFD78K0 (PC-9800 series, IBM PC/AT and compatible machines)                                                                     |

Remark  $\infty \infty$  in the part number differs depending on the host machine and OS used.



| _    | xxxx | Host machine   | OS                                                    | Supply media |
|------|------|----------------|-------------------------------------------------------|--------------|
|      | 5A13 |                | MS-DOS<br>(Ver. 3.30 to<br>Ver. 6.2 <sup>Note</sup> ) | 3.5" 2HD     |
| 5A10 | 5A10 | PC-9800 series |                                                       | 5" 2HD       |

Note Although MS-DOS Ver. 5.0 and above have a task swap function, this function cannot be used with this software.



μ \$0000xFI78K0

μ SxxxFD78K0



| <br>xxxx | Host machine                      | OS           | Supply media |
|----------|-----------------------------------|--------------|--------------|
| 7B13     | IBM PC/AT and compatible machines | Refer to A.4 | 3.5" 2HC     |
| 7B10     |                                   |              | 5" 2HC       |

🖬 6427525 0099720 811 🎟

Powered by ICminer.com Electronic-Library Service CopyRight 2003

#### APPENDIX C REGISTER INDEX

# C.1 Register Index (In Alphabetical Order with Respect to the Register Name)

#### [A]

A/D converter mode register 0 (ADM0) ... 130, 144 A/D conversion result register (ADCR0) ... 129, 143 Analog input channel specification register 0 (ADS0) ... 132, 146 Asynchronous serial interface mode register 0 (ASIM00) ... 159, 166, 167 Asynchronous serial interface mode register 1 (ASIM01) ... 159, 166, 167 Asynchronous serial interface status register 0 (ASIS00) ... 162, 169 Asynchronous serial interface status register 1 (ASIS01) ... 162, 169

#### [B]

Baud rate generator control register 0 (BRGC00) ... 163, 170 Baud rate generator control register 1 (BRGC01) ... 163, 170

# [D]

Dead time reload register (DTIME) ... 86

#### [E]

8-bit compare register 50 (CR50) ... 101
8-bit compare register 51 (CR51) ... 101
8-bit compare register 52 (CR52) ... 101
8-bit timer counter 50 (TM50) ... 101
8-bit timer counter 51 (TM51) ... 101
8-bit timer mode control register 50 (TMC50) ... 102
8-bit timer mode control register 51 (TMC51) ... 102
8-bit timer mode control register 52 (TMC52) ... 102
8-bit timer mode control register 52 (TMC52) ... 102
8-bit timer mode control register 52 (TMC52) ... 102
8-bit timer mode control register 52 (TMC52) ... 102
8-bit timer mode control register 52 (TMC52) ... 102
8-bit timer mode control register 52 (TMC52) ... 102

#### [I]

Interrupt mask flag register 0H (MK0H) ... 189 Interrupt mask flag register 0L (MK0L) ...189 Interrupt request flag register 0H (IF0H) ...188 Interrupt request flag register 0L (IF0L) ...188 Inverter timer control register 7 (TMC7) ... 87 Inverter timer mode register 7 (TMM7) ... 89

#### [M]

Memory extension mode register (MEM) ... 204 Memory extension wait setting register (MM) ... 205 Memory size select register (IMS) ... 206

🎟 6427525 0099721 758 🖿

[0]

Oscillation stabilization time select register (OSTS) ... 123, 214

[P]

Port 0 (P0) ... 57 Port 1 (P1) ... 58 Port 2 (P2) ... 59 Port 3 (P3) ... 60 Port 4 (P4) ... 61 Port 5 (P5) ... 62 Port 6 (P6) ... 63 Port mode register 0 (PM0) ... 64 Port mode register 2 (PM2) ... 64 Port mode register 3 (PM3) ... 64 Port mode register 4 (PM4) ... 64 Port mode register 5 (PM5) ... 64 Port mode register 6 (PM6) ... 64 Priority specification flag register 0H (PR0H) ... 190 Priority specification flag register OL (PROL) ... 190 Processor clock control register (PCC) ... 68 Pull-up resistor option register 0 (PU0) ... 65 Pull-up resistor option register 2 (PU2) ... 65 Pull-up resistor option register 3 (PU3) ... 65 Pull-up resistor option register 4 (PU4) ... 65 Pull-up resistor option register 5 (PU5) ... 65 Pull-up resistor option register 6 (PU6) ... 65

#### [R]

Real-time output buffer register H (RTBH0) ... 77 Real-time output buffer register L (RTBL0) ... 77 Real-time output port control register (RTPC0) ... 79 Real-time output port mode register (RTPM0) ... 78 Receive buffer register 0 (RXB00) ... 158 Receive buffer register 1 (RXB01) ... 158

# [T]

262

10-bit buffer register 0 (BFCM0) ... 85 10-bit buffer register 1 (BFCM1) ... 85 10-bit buffer register 2 (BFCM2) ... 85 10-bit buffer register 3 (BFCM3) ... 85 10-bit compare register 0 (CM0) ... 85 10-bit compare register 1 (CM1) ... 85 10-bit compare register 2 (CM2) ... 85 10-bit compare register 3 (CM3) ... 85 Timer clock select register 50 (TCL50) ... 106 Timer clock select register 51 (TCL51) ... 106 Timer clock select register 52 (TCL52) ... 106 Transmit shift register 0 (TXS00) ... 158

6427525 0099722 694 📰

```
Transmit shift register 1 (TXS01) ... 158
```

## [W]

Watchdog timer clock select register (WDCS) ... 121 Watchdog timer mode register (WDTM) ... 122

# L 64275250099723520 🖿

\_ -- · · · ·

# C.2 Register Index (In Alphabetical Order with Respect to the Register Symbol)

| <b>7 A</b> | ,              |                                                             |
|------------|----------------|-------------------------------------------------------------|
| [A         | -              | A/D conversion requit register 120, 142                     |
|            |                | A/D conversion result register 129, 143                     |
|            | ADS0:<br>ADM0: | Analog input channel specification register 0 132, 146      |
|            |                | A/D converter mode register 0 130, 144                      |
|            |                | Asynchronous serial interface mode register 0 159, 166, 167 |
|            |                | Asynchronous serial interface mode register 1 159, 166, 167 |
|            |                | Asynchronous serial interface status register 0 162, 169    |
|            | A31301.        | Asynchronous serial interface status register 1 162, 169    |
| [B         | 1              |                                                             |
| 1-         |                | 10-bit buffer register 0 85                                 |
|            |                | 10-bit buffer register 1 85                                 |
|            |                | 10-bit buffer register 2 85                                 |
|            |                | 10-bit buffer register 3 85                                 |
|            |                | Baud rate generator control register 0 163, 170             |
|            |                | Baud rate generator control register 1 163, 170             |
|            | 0.10001        |                                                             |
| [C]        | 1              |                                                             |
| • •        | СМ0:           | 10-bit compare register 0 85                                |
|            | CM1:           | 10-bit compare register 1 85                                |
|            | CM2:           | 10-bit compare register 2 85                                |
|            | CM3:           | 10-bit compare register 3 85                                |
|            | CR50:          | 8-bit compare register 50 101                               |
|            | CR51:          | 8-bit compare register 51 101                               |
|            | CR52:          | 8-bit compare register 52 101                               |
|            |                |                                                             |
| [D]        |                |                                                             |
|            | DTIME:         | Dead time reload register 86                                |
|            |                | -                                                           |
| [E]        |                |                                                             |
|            | EGN:           | External interrupt falling edge enable register 191         |
|            | EGP:           | External interrupt rising edge enable register 191          |
|            |                |                                                             |
| [1]        |                |                                                             |
|            | IF0H:          | Interrupt request flag register 0H 188                      |
|            | IF0L:          | Interrupt request flag register 0L 188                      |
|            | IMS:           | Memory size select register 206                             |
|            |                |                                                             |
| [M]        |                |                                                             |
|            | MEM:           | Memory extension mode register 204                          |
|            | MKOH:          | Interrupt mask flag register 0H 189                         |
|            | MKOL:          | Interrupt mask flag register 0L 189                         |
|            | MM:            | Memory extension wait setting register 205                  |
|            |                |                                                             |
| [0]        |                |                                                             |
|            | OSTS:          | Oscillation stabilization time select register 123, 214     |
|            |                |                                                             |
|            |                |                                                             |
| 264        |                |                                                             |
|            |                | 6427525 0099724 467                                         |

Powered by ICminer.com Electronic-Library Service CopyRight 2003

| 11 |  |
|----|--|
|    |  |
|    |  |

| P0:   | Port 0 57                                   |
|-------|---------------------------------------------|
| P1:   | Port 1 58                                   |
| P2:   | Port 2 59                                   |
| P3:   | Port 3 60                                   |
| P4:   | Port 4 61                                   |
| P5:   | Port 5 62                                   |
| P6:   | Port 6 63                                   |
| PCC:  | Processor clock control register 68         |
| PM0:  | Port mode register 0 64                     |
| PM2:  | Port mode register 2 64                     |
| PM3:  | Port mode register 3 64                     |
| PM4:  | Port mode register 4 64                     |
| PM5:  | Port mode register 5 64                     |
| PM6:  | Port mode register 6 64                     |
| PR0H: | Priority specification flag register 0H 190 |
| PROL: | Priority specification flag register 0L 190 |
| PU0:  | Pull-up resistor option register 0 65       |
| PU2:  | Pull-up resistor option register 2 65       |
| PU3:  | Pull-up resistor option register 3 65       |
| PU4:  | Pull-up resistor option register 4 65       |
| PU5:  | Pull-up resistor option register 5 65       |
| PU6:  | Pull-up resistor option register 6 65       |

# [R]

| RTBH0: | Real-time output buffer register H 77     |
|--------|-------------------------------------------|
| RTBL0: | Real-time output buffer register L 77     |
| RTPC0: | Real-time output port control register 79 |
| RTPM0: | Real-time output port mode register 78    |
| RXB00: | Receive buffer register 0 158             |
| RXB01: | Receive buffer register 1 158             |
|        |                                           |

# **[T]**

| TCL50: | Timer clock select register 50 106       |
|--------|------------------------------------------|
| TCL51: | Timer clock select register 51 106       |
| TCL52: | Timer clock select register 52 106       |
| TM50:  | 8-bit timer counter 50 101               |
| TM51:  | 8-bit timer counter 51 101               |
| TM52:  | 8-bit timer counter 52 101               |
| TMC7:  | Inverter timer control register 7 87     |
| TMC50: | 8-bit timer mode control register 50 102 |
| TMC51: | 8-bit timer mode control register 51 102 |
| TMC52: | 8-bit timer mode control register 52 102 |
| TMM7:  | Inverter timer mode register 7 89        |
| TXS00: | Transmit shift register 0 158            |
| TXS01: | Transmit shift register 1 158            |

🔲 6427525 0099725 3T3 📖

----

- · -