# M30201 Group User's manual (tentative)

Specifications written in this user's manual are believed to be accurate, but are not guaranteed to be entirely free of error.

Specifications in this manual may be changed for functional or performance improvements. Please make sure your manual is the latest edition.

| keep s | safety | first  | in  | vour | circuit | designs | ! |     |
|--------|--------|--------|-----|------|---------|---------|---|-----|
| veeh a | saicty | III St | 111 | your | Circuit | uesign  | J | 0 : |

▶ Mitsubishi Electric Corporation puts the maximum effort into making semiconductor products better and more reliable, but there is always the possibility that trouble may occur with them. Trouble with semiconductors may lead to personal injury, fire or property damage. Remember to give due consideration to safety when making your circuit designs, with appropriate measures such as (i) placement of substitutive, auxiliary circuits, (ii) use of non-flammable material or (iii) prevention against any malfunction or mishap.

| Notes | regarding | these | materials | s |
|-------|-----------|-------|-----------|---|
|       |           |       |           |   |

- ♣ These materials are intended as a reference to assist our customers in the selection of the Mitsubishi semiconductor product best suited to the customer's application; they do not convey any license under any intellectual property rights, or any other rights, belonging to Mitsubishi Electric Corporation or a third party.
- ▶ Mitsubishi Electric Corporation assumes no responsibility for any damage, or infringement of any third-party's rights, originating in the use of any product data, diagrams, charts or circuit application examples contained in these materials.
- ♣ All information contained in these materials, including product data, diagrams and charts, represent information on products at the time of publication of these materials, and are subject to change by Mitsubishi Electric Corporation without notice due to product improvements or other reasons. It is therefore recommended that customers contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor for the latest product information before purchasing a product listed herein.
- ▶ Mitsubishi Electric Corporation semiconductors are not designed or manufactured for use in a device or system that is used under circumstances in which human life is potentially at stake. Please contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor when considering the use of a product contained herein for any specific purposes, such as apparatus or systems for transportation, vehicular, medical, aerospace, nuclear, or undersea repeater use.
- ➤ The prior written approval of Mitsubishi Electric Corporation is necessary to reprint or reproduce in whole or in part these materials.
- ▶ If these products or technologies are subject to the Japanese export control restrictions, they must be exported under a license from the Japanese government and cannot be imported into a country other than the approved destination. Any diversion or reexport contrary to the export control laws and regulations of JAPAN and/or the country of destination is prohibited.
- ▶ Please contact Mitsubishi Electric Corporation or an authorized Mitsubishi Semiconductor product distributor for further details on these materials or the products contained therein.

#### **Preface**

This user's manual describes the function and features of the Mitsubishi M30201 CMOS 16-bit microcomputer. The software features are explained to help designers take full advantage of the M16C functions.

For details about the software, please refer to the "M16C/60, M16C/20 series software manual", and for the development support tools, please refer to the related instruction manual.

| Chapter 1 Hardware                                      | _ 1 |
|---------------------------------------------------------|-----|
|                                                         |     |
| Chapter 2 Peripheral Functions Usage                    | 2   |
|                                                         |     |
| Chapter 3 Examples of Peripheral Functions Applications | 3   |
|                                                         |     |
| Chapter 4 Interrupt                                     | _ 4 |
|                                                         |     |
| Chapter 5 Standard Characteristics                      | _5  |
|                                                         |     |

#### How to Use This Manual

This user's manual is written for the M30201 group.

The reader of this manual is expected to have the basic knowledge of electric and logic circuits and microcomputers.

This manual is for the use of the models below.

- M30201M2-XXXSP/FP
- M30201M2T-XXXSP/FP
- M30201M4-XXXSP/FP

- M30201M4T-XXXSP/FP
- M30201F6SP/FP
- M30201F6TSP/FP

These products have similar features except for the memories, which differ from one product to another. This manual gives descriptions of M30201M4-XXXSP. Memories built-in are as shown below. Be careful when writing a program, as the memories have different capacities.

The figure of each register configuration describes its functions, contents at reset, and attributes as follows:



This manual comprises of eight chapters. Use the suggested chapters as a reference for the following topics:



| * To understand hardware specifications Chapter 1 Hardware                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------|
| * To understand the basic way of using peripheral features and the operation timing                                               |
| * To observe applications of peripheral features                                                                                  |
| * To understand interrupt timing in detail                                                                                        |
| * To understand standard data                                                                                                     |
| This manual includes a quick reference immediately following the Table of Contents, indicate the page of the topic to be pursued. |
| * To find a page describing a specific register by the register address                                                           |

### M16C Family-related document list

## Usages (Microcomputer development flow)



### M16C Family Line-up



## **Table of Contents**

| Description                        | 2   |
|------------------------------------|-----|
| Memory                             |     |
| Central Processing Unit (CPU)      |     |
| Reset                              |     |
| Software Reset                     |     |
| Software wait                      |     |
| Clock Generating Circuit           | 19  |
| Clock Control                      |     |
| Clock Output                       | 23  |
| Stop Mode                          | 24  |
| Wait Mode                          | 24  |
| Power Saving                       | 26  |
| Protection                         | 28  |
| Interrupt                          | 29  |
| Watchdog Timer                     | 47  |
| Timer                              | 49  |
| Timer A                            | 50  |
| Timer B                            | 60  |
| Timer X                            | 66  |
| Serial I/O                         | 76  |
| A-D Converter                      | 90  |
| Programmable I/O Ports             | 100 |
| Usage Precaution                   | 108 |
| Electrical characteristics         | 112 |
| Outline Performance (Flash Memory) | 126 |
| Flash Memory                       | 127 |
| CPU Rewrite Mode                   | 128 |
| Parallel I/O Mode                  | 135 |
| Standard Serial I/O Mode           | 147 |

## Chapter 2 Peripheral Functions Usage \_\_\_\_\_

| 2 | 1 Protect                                                                                              | .160  |
|---|--------------------------------------------------------------------------------------------------------|-------|
|   | 2.1.3 Precaution for Protect                                                                           | .161  |
| 2 | 2 Timer A                                                                                              | .162  |
|   | 2.2.1 Overview                                                                                         | .162  |
|   | 2.2.2 Operation of Timer A (timer mode)                                                                | . 168 |
|   | 2.2.3 Operation of Timer A (timer mode, gate function selected)                                        | . 170 |
|   | 2.2.4 Operation of Timer A (timer mode, pulse output function selected)                                | . 172 |
|   | 2.2.5 Operation of Timer A (event counter mode, reload type selected)                                  | . 174 |
|   | 2.2.6 Operation of Timer A (event counter mode, free run type selected)                                | . 176 |
|   | 2.2.7 Operation of timer A (2-phase pulse signal process in event counter mod normal mod lected)       |       |
|   | 2.2.8 Operation of timer A (2-phase pulse signal process in event counter mode,multiply-by-4 selected) |       |
|   | 2.2.9 Operation of Timer A (one-shot timer mode)                                                       | .182  |
|   | 2.2.10 Operation of Timer A (one-shot timer mode, external trigger selected)                           | . 184 |
|   | 2.2.11 Operation of Timer A (pulse width modulation mode, 16-bit PWM mode selected)                    | . 186 |
|   | 2.2.12 Operation of Timer A (pulse width modulation mode, 8-bit PWM mode selected)                     | . 188 |
|   | 2.2.13 Precautions for Timer A (timer mode)                                                            | .190  |
|   | 2.2.14 Precautions for Timer A (event counter mode)                                                    | . 191 |
|   | 2.2.15 Precautions for Timer A (one-shot timer mode)                                                   | .192  |
|   | 2.2.16 Precautions for Timer A (pulse width modulation mode)                                           | . 193 |
| 2 | 3 Timer B                                                                                              | .194  |
|   | 2.3.1 Overview                                                                                         | .194  |
|   | 2.3.2 Operation of Timer B (timer mode)                                                                | . 198 |
|   | 2.3.3 Operation of Timer B (event counter mode)                                                        | .200  |
|   | 2.3.4 Operation of Timer B (pulse period measurement mode)                                             | .202  |
|   | 2.3.5 Operation of Timer B (pulse width measurement mode)                                              | . 204 |
|   | 2.3.6 Precautions for Timer B (timer mode, event counter mode)                                         | . 206 |
|   | 2.3.7 Precautions for Timer B (pulse period/pulse width measurement mode)                              | . 207 |
| 2 | 4 Timer X                                                                                              | .208  |
|   | 2.4.1 Overview                                                                                         | .208  |
|   | 2.4.2 Operation of Timer X (timer mode)                                                                | .212  |
|   | 2.4.3 Operation of Timer X (timer mode, gate function selected)                                        | .214  |
|   | 2.4.4 Operation of Timer X (timer mode, pulse output function selected)                                | .216  |

| 2.4.5 Operation of Timer X (event counter mode, reload type selected)                                                             | 218     |
|-----------------------------------------------------------------------------------------------------------------------------------|---------|
| 2.4.6 Operation of Timer X (event counter mode, free run type selected)                                                           | 220     |
| 2.4.7 Operation of Timer X (one-shot timer mode)                                                                                  | 222     |
| 2.4.8 Operation of Timer X (pulse period measurement mode)                                                                        | 224     |
| 2.4.9 Operation of Timer X (pulse width measurement mode)                                                                         | 226     |
| 2.4.10 Operation of Timer X (pulse width modulation mode, 16-bit PWM mode select                                                  | ted)228 |
| 2.4.11 Operation of Timer X (pulse width modulation mode, 8-bit PWM mode selecte                                                  | ed)230  |
| 2.4.12 Precautions for Timer X (timer mode, event counter mode)                                                                   | 232     |
| 2.4.13 Precautions for Timer X (one-shot timer mode)                                                                              | 233     |
| 2.4.14 Precautions for Timer X (pulse period/pulse width measurement mode)                                                        | 234     |
| 2.4.15 Precautions for Timer X (pulse width modulation mode)                                                                      | 235     |
| .5 Clock-Synchronous Serial I/O                                                                                                   | 236     |
| 2.5.1 Overview                                                                                                                    | 236     |
| 2.5.2 Operation of Serial I/O (transmission in clock-synchronous serial I/O mode)                                                 | 242     |
| 2.5.3 Operation of the Serial I/O (transmission in clock-synchronous serial I/O mode output from multiple pins function selected) |         |
| 2.5.4 Operation of Serial I/O (reception in clock-synchronous serial I/O mode)                                                    | 250     |
| 2.5.5 Precautions for Serial I/O (in clock-synchronous serial I/O)                                                                | 254     |
| 2.6 Clock-Asynchronous Serial I/O (UART)                                                                                          | 256     |
| 2.6.1 Overview                                                                                                                    | 256     |
| 2.6.2 Operation of Serial I/O (transmission in UART mode)                                                                         | 264     |
| 2.6.3 Operation of Serial I/O (reception in UART mode)                                                                            | 268     |
| 2.7 A-D Converter                                                                                                                 | 272     |
| 2.7.1 Overview                                                                                                                    | 272     |
| 2.7.2 Operation of A-D converter (one-shot mode)                                                                                  | 278     |
| 2.7.3 Operation of A-D Converter (in repeat mode)                                                                                 | 280     |
| 2.7.4 Operation of A-D Converter (in single sweep mode)                                                                           | 282     |
| 2.7.5 Operation of A-D Converter (in repeat sweep mode 0)                                                                         | 284     |
| 2.7.6 Operation of A-D Converter (in repeat sweep mode 1)                                                                         | 286     |
| 2.7. 7 Precautions for A-D Converter                                                                                              | 288     |
| 2.7.8 Method of A-D Conversion (10-bit mode)                                                                                      | 289     |
| 2.7.9 Method of A-D Conversion (8-bit mode)                                                                                       | 291     |
| 2.7.10 Absolute Accuracy and Differential Non-Linearity Error                                                                     | 293     |
| 2.7.11 Internal Equivalent Circuit of Analog Input                                                                                | 295     |
| 2.7.12 Sensor's Output Impedance under A-D Conversion                                                                             | 296     |

| 2.8 watchdog timer                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 290                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|
| 2.8.1 Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 298                                                       |
| 2.8.2 Operation of Watchdog Timer                                                                                                                                                                                                                                                                                                                                                                                                                                        | 300                                                       |
| 2.9 Address Match Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                              | 302                                                       |
| 2.9.1 Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 302                                                       |
| 2.9.2 Operation of Address Match Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                               | 304                                                       |
| 2.10 Key-Input Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 306                                                       |
| 2.10.1 Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 306                                                       |
| 2.10.2 Operation of Key-Input Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                  | 308                                                       |
| 2.11 Power Control                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 310                                                       |
| 2.11.1 Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 310                                                       |
| 2.11.2 Stop Mode Set-Up                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 315                                                       |
| 2.11.3 Wait Mode Set-Up                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 316                                                       |
| 2.11.4 Precautions in Power Control                                                                                                                                                                                                                                                                                                                                                                                                                                      | 317                                                       |
| 2.12 Programmable I/O Ports                                                                                                                                                                                                                                                                                                                                                                                                                                              | 318                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 240                                                       |
| 2.12.1 Overview  Chapter 3 Examples of Peripheral functions App                                                                                                                                                                                                                                                                                                                                                                                                          |                                                           |
| 2.12.1 Overview  Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers                                                                                                                                                                                                                                                                                                                                                                                  | lications                                                 |
| Chapter 3 Examples of Peripheral functions App                                                                                                                                                                                                                                                                                                                                                                                                                           | lications                                                 |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers                                                                                                                                                                                                                                                                                                                                                                                                   | lications326                                              |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers                                                                                                                                                                                                                                                                                                                                                                                                   | lications326<br>330<br>334                                |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers  3.2 Variable-Period Variable-Duty PWM Output  3.3 Delayed One-Shot Output                                                                                                                                                                                                                                                                                                                        | lications                                                 |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers  3.2 Variable-Period Variable-Duty PWM Output  3.3 Delayed One-Shot Output  3.4 Buzzer Output                                                                                                                                                                                                                                                                                                     | 326<br>                                                   |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers  3.2 Variable-Period Variable-Duty PWM Output  3.3 Delayed One-Shot Output  3.4 Buzzer Output  3.5 Solution for External Interrupt Pins Shortage                                                                                                                                                                                                                                                  | 326<br>                                                   |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers                                                                                                                                                                                                                                                                                                                                                                                                   | 326<br>                                                   |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers  3.2 Variable-Period Variable-Duty PWM Output  3.3 Delayed One-Shot Output  3.4 Buzzer Output  3.5 Solution for External Interrupt Pins Shortage  3.6 Controlling Power Using Stop Mode                                                                                                                                                                                                           | 326<br>                                                   |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers 3.2 Variable-Period Variable-Duty PWM Output 3.3 Delayed One-Shot Output 3.4 Buzzer Output 3.5 Solution for External Interrupt Pins Shortage 3.6 Controlling Power Using Stop Mode 3.7 Controling Power Using Wait Mode  Chapter 4 Interrupt                                                                                                                                                      | 326<br>                                                   |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers                                                                                                                                                                                                                                                                                                                                                                                                   | lications                                                 |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers                                                                                                                                                                                                                                                                                                                                                                                                   | lications                                                 |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers                                                                                                                                                                                                                                                                                                                                                                                                   | lications                                                 |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers                                                                                                                                                                                                                                                                                                                                                                                                   | lications                                                 |
| Chapter 3 Examples of Peripheral functions App  3.1 Long-Period Timers 3.2 Variable-Period Variable-Duty PWM Output 3.3 Delayed One-Shot Output 3.4 Buzzer Output 3.5 Solution for External Interrupt Pins Shortage 3.6 Controlling Power Using Stop Mode 3.7 Controling Power Using Wait Mode  Chapter 4 Interrupt 4.1 Overview of Interrupts 4.1.1 Type of Interrupts 4.1.2 Software Interrupts 4.1.3 Hardware Interrupts 4.1.4 Interrupts and Interrupt Vector Tables | 326   330   334   342   346   352   353   354   355   357 |

| 4.2.2 Interrupt Request Bit                                                                                                                                                                                                                                         | 359                                    |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| 4.2.3 Interrupt Priority Level Select Bit and Processor Interrupt Priority Level (IPL)                                                                                                                                                                              | 360                                    |
| 4.2.4 Rewrite the interrupt control register                                                                                                                                                                                                                        | 361                                    |
| 4.3 Interrupt Sequence                                                                                                                                                                                                                                              | 362                                    |
| 4.3.1 Interrupt Response Time                                                                                                                                                                                                                                       | 362                                    |
| 4.3.2 Variation of IPL when Interrupt Request is Accepted                                                                                                                                                                                                           | 363                                    |
| 4.3.3 Saving Registers                                                                                                                                                                                                                                              | 364                                    |
| 4.4 Returning from an Interrupt Routine                                                                                                                                                                                                                             | 366                                    |
| 4.5 Interrupt Priority                                                                                                                                                                                                                                              | 366                                    |
| 4.6 Multiple Interrupts                                                                                                                                                                                                                                             | 368                                    |
| 4.7 Precautions for Interrupts                                                                                                                                                                                                                                      | 370                                    |
|                                                                                                                                                                                                                                                                     |                                        |
|                                                                                                                                                                                                                                                                     |                                        |
| Chapter 5 Standard Characteristics                                                                                                                                                                                                                                  |                                        |
| Chapter 5 Standard Characteristics  5.1 Standard DC Characteristics                                                                                                                                                                                                 |                                        |
|                                                                                                                                                                                                                                                                     | 374                                    |
| 5.1 Standard DC Characteristics                                                                                                                                                                                                                                     | 374                                    |
| 5.1 Standard DC Characteristics                                                                                                                                                                                                                                     | 374<br>374<br>377                      |
| 5.1 Standard DC Characteristics  5.1.1 Standard Ports Characteristics  5.1.2 Standard Characteristics of Icc-f(XIN)                                                                                                                                                 | 374<br>374<br>377<br>379               |
| 5.1 Standard DC Characteristics  5.1.1 Standard Ports Characteristics  5.1.2 Standard Characteristics of ICC-f(XIN)  5.2 Standard Characteristics of Pull-Up Resistor                                                                                               | 374<br>374<br>377<br>379<br>380        |
| 5.1 Standard DC Characteristics                                                                                                                                                                                                                                     | 374<br>374<br>377<br>379<br>380        |
| 5.1 Standard DC Characteristics  5.1.1 Standard Ports Characteristics  5.1.2 Standard Characteristics of ICC-f(XIN)  5.2 Standard Characteristics of Pull-Up Resistor  5.3 Standard DC Characteristics (Flash memory version)  5.3.1 Standard Ports Characteristics | 374<br>374<br>377<br>379<br>380<br>380 |

## Quick Reference to Pages Classified by Address

| 000016   000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   0000176   000017   | Addres             | ss Register                                | Page |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------------------------------|------|
| 000216   000316   000416   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   0   | 000016             |                                            |      |
| 000316   000416   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   000516   0   | 000116             |                                            |      |
| Processor mode register 0 (PM0)   Processor mode register 1 (PM1)   System clock control register 1 (CM1)   2   2   3   3   3   3   3   3   3   3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    |                                            |      |
| 000616                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                    |                                            |      |
| Processor mode register 1 (PMT)   2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 000416             |                                            | 17   |
| System clock control register 1 (CM1)   2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                    |                                            | ''   |
| Match   Matc   |                    |                                            | 2    |
| Match   Matc   |                    | System clock control register 1 (CM1)      |      |
| O0001-6   O0101-6   O010   |                    | Address with intervent and black intervent |      |
| 000B16 000C16 000D16                         |                    |                                            | _    |
| 000C16   000D16   000E16   0   |                    | Protect register (PRCR)                    | 28   |
| 000D16   000E16   0   |                    |                                            |      |
| Watchdog timer start register (WDTS)   Watchdog timer control register (WDC)   Watchdog timer control register (WDC)   48   Watchdog timer control register (WDC)   45   Watchdog timer control registe   |                    |                                            |      |
| Watchdog timer control register (WDC)   45                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                    | Watchdog timer start register (WDTS)       |      |
| 001016 001116 001116 001116 001016 001016 001016 001016 001016 001016 001016 001017 001017 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                    | Watchdog timer control register (WDC)      | 48   |
| 001116 001216 001316 001316 001418 001616 001716 001816 001918 001918 0011816 001616 001716 001818 00101818 0011818 0011818 0011818 001218 002018 002118 002018 002118 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002218 002318 002318 002318 002318 002318 002318 002318 002318 002318 002318 002318 002318 002318 002318 002318 002318 002318 002318 003318 003318 003318 003318 003318 003318 003318 003318                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                    | vateriog timer control register (vvbo)     |      |
| 001216 001316 001416 001616 001716 001818 001916 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 001016 00 |                    | Address match interrupt register (IRMADO)  | 15   |
| 001316 001418 001518 001618 001618 001818 001918 0011418 0011818 0011418 0011518 0011518 0011518 0011518 0011518 0011518 0011518 0011518 0011518 0012118 0022118 0022118 0022118 0022118 0022118 002218 002318 002418 002518 002618 002618 002618 002718 002818 002618 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00218 00318 00318 00318 00318 00318 00318 00318                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                    | Addition interrupt register o (INMADO)     | 70   |
| 001416 001516 001616 001716 001818 001918 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 001018 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 00118 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018 0018                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                    |                                            |      |
| 001616 001716 001816 001916 001016 001016 001016 001016 00116 00116 00116 002016 002016 002116 002216 002316 002416 002516 002616 002716 002816 002616 002716 002816 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                    |                                            |      |
| 001616 001716 001816 001916 001016 001016 001016 001016 001016 001016 002016 002016 002118 002216 002316 002416 002516 002616 002716 002816 002616 002716 002816 00216 00216 00216 00216 00216 002716 002816 00216 00216 00216 002716 00216 00216 00216 002716 00216 00216 002716 00216 002716 00216 002716 00216 002716 002716 002716 002716 002716 002716 002716 002716 002716 002716 002716 002716 002716 002716 002716 002716 002716 002716 002716 003716 003716 003716 003716 003716 003716 003716 003716 003716 003716 003716 003716                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 001516             | Address match interrupt register 1 (RMAD1) | 45   |
| 001816 001918 001A16 001B18 001C18 001E16 001E16 001F18 002018 002116 002216 002316 002416 002516 002616 002718 002816 002916 002816 002916 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 001616             | ,                                          |      |
| 001916 001A16 001B16 001C16 001D16 001E18 002F16 002016 002216 002318 002416 002516 002616 002718 002816 002816 002216 00216 00216 00216 00216 00216 002176 00216 002176 002176 002816 002176 002816 002176 002816 002176 002816 002176 002816 002716 002816 002716 002816 002716 002816 002716 002816 002716 003716 003716 003716 003816 003716 003816 003916 003816 003916 003816 003916                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 001716             |                                            |      |
| 001A16 001B16 001C16 001D16 001E16 001F16 002016 002016 002216 002318 002416 002516 002616 002716 002818 002818 002216 002216 002818 002B16 002C16 002D16 002C16 002D16 002C16 003016 003116 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316 003316                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 001816             |                                            |      |
| 001B16 001C16 001D16 001E16 001F16 002016 002116 002216 002316 002416 002516 002616 002716 002816 002916 002016 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 001916             |                                            |      |
| 001C16 001D16 001E16 001F16 002016 002116 002216 002316 002316 002416 002516 002616 002716 002816 002916 002016 002016 002016 002016 002016 002016 002016 002016 002016 002016 002016 002016 002016 002016 003016 003116 003016 003116 003316 003416 003516 003616 003716 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 001A16             |                                            |      |
| 001D16 001E16 001F16 002016 002116 002216 002316 002416 002516 002516 002616 002716 002816 002816 002016 002016 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00216 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316 00316                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 001B <sub>16</sub> |                                            |      |
| 001E16 001F16 002016 002116 002216 002316 002416 002516 002616 002716 002816 002916 002016 002016 002016 002016 002016 002016 002016 002016 002016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 001C <sub>16</sub> |                                            |      |
| 001F16 002016 002116 002216 002216 002316 002416 002516 002616 002716 002816 002916 002A16 002B16 002C16 002D16 002E16 002E16 003016 003116 003316 003316 003416 003516 003616 003716 003816 003716 003816 003916 003816 003916 003916 003916 003916 003916 003916 003916 003916 003916 003916 003916                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 001D <sub>16</sub> |                                            |      |
| 002016 00216 00216 002316 002416 002516 002616 002716 002816 002916 002016 002016 002016 002016 002016 002016 002016 002016 002016 002016 002016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016 003016                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 001E <sub>16</sub> |                                            |      |
| 002116 002216 002316 002416 002516 002616 002716 002816 002916 002A16 002B16 002C16 002D16 002E16 003016 003116 003316 003316 003416 003516 003616 003716 003816 003916 003816 003916 003916 003916 003916 003916 003916 003916 003916 003916 003916 003916                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 001F <sub>16</sub> |                                            |      |
| 002216 002316 002416 002516 002616 002716 002816 002916 002016 002D16 002D16 002E16 003016 003116 003316 003316 003416 003516 003616 003716 003816 003916 003816 003916 003016 00316                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 002016             |                                            |      |
| 002316 002416 002516 002616 002716 002816 002916 002016 002016 002D16 002D16 002E16 003016 003116 003316 003316 003416 003516 003616 003716 003816 003916 003816 003916 003816 003916                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                    |                                            |      |
| 002416 002516 002616 002716 002816 002916 002016 002016 002016 002016 002016 002016 003016 003116 003316 003316 003416 003516 003516 003616 003716 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 002216             |                                            |      |
| 002516 002616 002716 002816 002916 002016 002016 002016 002016 002016 002016 003016 003116 003316 003316 003416 003516 003616 003716 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 002316             |                                            |      |
| 002616 002716 002816 002916 002016 002016 002016 002016 002016 002016 002016 00316 003116 003316 003316 003416 003516 003516 003616 003716 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816 003816                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                    |                                            |      |
| 002716 002816 002916 002A16 002B16 002C16 002D16 002E16 002E16 00316 003116 003316 003316 003416 003516 003516 003616 003716 003816 003816 003816 003816 003816 003816 003816 003816 003816                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                    |                                            |      |
| 002816 002916 002A16 002B16 002C16 002D16 002E16 002E16 00316 003116 003316 003316 003416 003516 003616 003716 003816 003916 003816 003916 003A16 003B16 003B16 003C16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                    |                                            |      |
| 002916 002A16 002B16 002C16 002D16 002E16 002F16 003016 003116 003316 003316 003416 003516 003516 003616 003716 003816 003816 003816 003816 003816 003816 003816 003016                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                    |                                            |      |
| 002A16 002B16 002C16 002D16 002E16 002E16 003016 003116 003316 003316 003416 003516 003616 003716 003816 003816 003916 003A16 003A16 003B16 003B16 003C16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                    |                                            |      |
| 002B16 002C16 002D16 002E16 002F16 003016 003116 003216 003316 003416 003516 003616 003716 003816 003816 003916 003A16 003B16 003B16 003C16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                    |                                            |      |
| 002C16 002D16 002E16 002F16 003016 003116 003216 003316 003416 003516 003616 003716 003816 003916 003A16 003A16 003B16 003B16 003C16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                    |                                            |      |
| 002D16 002E16 002F16 003016 003016 003116 003216 003316 003416 003516 003616 003716 003816 003916 003A16 003A16 003B16 003B16 003C16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                    |                                            |      |
| 002E16 002F16 003016 003116 003216 003316 003416 003516 003616 003716 003816 003916 003A16 003A16 003B16 003B16 003C16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                    |                                            |      |
| 002F16 003016 003116 003216 003316 003416 003516 003616 003716 003816 003916 003A16 003A16 003B16 003B16 003C16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                    |                                            |      |
| 003016 003116 003216 003316 003416 003516 003616 003716 003816 003916 003A16 003B16 003B16 003C16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    |                                            |      |
| 003116<br>003216<br>003316<br>003416<br>003516<br>003616<br>003716<br>003816<br>003916<br>003A16<br>003B16<br>003B16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                    |                                            |      |
| 003216<br>003316<br>003416<br>003516<br>003616<br>003716<br>003816<br>003916<br>003A16<br>003B16<br>003B16<br>003C16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                    |                                            |      |
| 003316<br>003416<br>003516<br>003616<br>003716<br>003816<br>003916<br>003A16<br>003B16<br>003B16<br>003C16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                    |                                            |      |
| 003516<br>003616<br>003716<br>003816<br>003916<br>003A16<br>003B16<br>003C16<br>003D16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                    |                                            |      |
| 003616<br>003716<br>003816<br>003916<br>003A16<br>003B16<br>003C16<br>003D16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                    |                                            |      |
| 003716<br>003816<br>003916<br>003A16<br>003B16<br>003C16<br>003D16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 003516             |                                            |      |
| 003816<br>003916<br>003A16<br>003B16<br>003C16<br>003D16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 003616             |                                            |      |
| 003916<br>003A16<br>003B16<br>003C16<br>003D16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                    |                                            |      |
| 003A16<br>003B16<br>003C16<br>003D16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 003816             |                                            |      |
| 003B16<br>003C16<br>003D16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 003916             |                                            |      |
| 003C16<br>003D16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 003A16             |                                            |      |
| 003D16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 003B <sub>16</sub> |                                            |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 003C <sub>16</sub> |                                            |      |
| 003E16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 003D16             |                                            |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 003E <sub>16</sub> |                                            |      |

| Addres             | s Register                                        | Page |
|--------------------|---------------------------------------------------|------|
| 004016             |                                                   |      |
| 004116             |                                                   |      |
| 004216             |                                                   |      |
| 004316             |                                                   |      |
| 004416             |                                                   |      |
| 004516             |                                                   |      |
| 004616             |                                                   |      |
| 004716             |                                                   |      |
| 004816             |                                                   |      |
| 004916             |                                                   |      |
| 004A16             |                                                   |      |
| 004B <sub>16</sub> |                                                   |      |
| 004C16             |                                                   |      |
| 004D16             | Key input interrupt control register (KUPIC)      | 35   |
| 004E <sub>16</sub> | A-D conversion interrupt control register (ADIC)  |      |
| 004F16             |                                                   |      |
| 005016             |                                                   |      |
| 005116             | UART0 transmit interrupt control register (S0TIC) |      |
| 005216             | UARTO receive interrupt control register (SORIC)  |      |
| 005316             | UART1 transmit interrupt control register (S1TIC) |      |
| 005416             | UART1 receive interrupt control register (S1RIC)  | 35   |
| 005516             | Timer A0 interrupt control register (TA0IC)       |      |
| 005616             | Timer X0 interrupt control register (TX0IC)       |      |
| 005716             | Timer X1 interrupt control register (TX1IC)       |      |
| 005816             | Timer X2 interrupt control register (TX2IC)       |      |
| 005916             |                                                   |      |
| 005A16             | Timer B0 interrupt control register (TB0IC)       | 35   |
| 005B <sub>16</sub> | Timer B1 interrupt control register (TB1IC)       |      |
| 005C16             |                                                   |      |
| 005D16             | INT0 interrupt control register (INT0IC)          | 35   |
| 005E16             | INT1 interrupt control register (INT1IC)          |      |
| 005F16             |                                                   |      |

## Quick Reference to Pages Classified by Address

| Addres                                   | ss Register                                      | Page |
|------------------------------------------|--------------------------------------------------|------|
| 038016                                   | Count start flag (TABSR)                         | 51   |
| 038116                                   | Clock prescaler reset flag (CPSRF)               |      |
| 038216                                   | One-shot start flag (ONSF)                       | 52   |
| 038316                                   | Trigger select register (TRGSR)                  |      |
| 038416                                   | Up-down flag (UDF)                               | 51   |
| 038516                                   |                                                  |      |
| 038616                                   | Timer A0 (TA0)                                   | 51   |
| 0387 <sub>16</sub><br>0388 <sub>16</sub> |                                                  |      |
| 038916                                   | Timer X0 (TX0)                                   |      |
| 038A16                                   |                                                  | -    |
| 038B <sub>16</sub>                       | Timer X1 (TX1)                                   | 67   |
| 038C <sub>16</sub>                       |                                                  | -    |
| 038D16                                   | Timer X2 (TX2)                                   |      |
| 038E <sub>16</sub>                       | Clock divided counter (CDC)                      |      |
| 038F <sub>16</sub>                       | Clock divided country (CDC)                      |      |
| 039016                                   | T' DO (TDO)                                      |      |
| 039116                                   | Timer B0 (TB0)                                   | 61   |
| 039216                                   | Timer B1 (TB1)                                   | 61   |
| 039316                                   | ווווסו טו (ווטו)                                 |      |
| 039416                                   |                                                  |      |
| 039516                                   |                                                  |      |
| 039616                                   | Timer A0 mode register (TA0MR)                   | 50   |
| 039716                                   | Timer X0 mode register (TX0MR)                   |      |
| 039816                                   | Timer X1 mode register (TX1MR)                   | 66   |
| 039916                                   | Timer X2 mode register (TX2MR)                   |      |
| 039A16                                   | T' DO L (TDOMB)                                  |      |
| 039B <sub>16</sub><br>039C <sub>16</sub> | Timer B0 mode register (TB0MR)                   | 60   |
| 039D16                                   | Timer B1 mode register (TB1MR)                   |      |
| 039E16                                   |                                                  |      |
| 039F16                                   |                                                  | -    |
| 03A016                                   | UART0 transmit/receive mode register (U0MR)      | 79   |
| 03A1 <sub>16</sub>                       | UARTO bit rate generator (U0BRG)                 | 13   |
| 03A216                                   | <u> </u>                                         | 78   |
| 03A316                                   | UART0 transmit buffer register (U0TB)            |      |
| 03A416                                   | UART0 transmit/receive control register 0 (U0C0) | 79   |
| 03A516                                   | UART0 transmit/receive control register 1 (U0C1) | 80   |
| 03A616                                   | UART0 receive buffer register (U0RB)             | 78   |
| 03A7 <sub>16</sub>                       | OARTO receive buller register (OORD)             | 70   |
| 03A816                                   | UART1 transmit/receive mode register (U1MR)      | 79   |
| 03A9 <sub>16</sub>                       | UART1 bit rate generator (U1BRG)                 |      |
| 03AA16                                   | UART1 transmit buffer register (U1TB)            | 78   |
| 03AB <sub>16</sub>                       | <b>5</b> ( ,                                     |      |
| 03AC16                                   | UART1 transmit/receive control register 0 (U1C0) | 79   |
| 03AD <sub>16</sub><br>03AE <sub>16</sub> | UART1 transmit/receive control register 1 (U1C1) | 80   |
| 03AE16<br>03AF16                         | UART1 receive buffer register (U1RB)             | 78   |
| 03B016                                   | UART transmit/receive control register 2 (UCON)  | 80   |
| 03B016                                   | OAKT transmittedelive control register 2 (OCON)  | 80   |
| 03B216                                   |                                                  | 1 1  |
| 03B316                                   |                                                  | 1    |
| 03B416                                   | Flash memory control register 0 (FCON0) (Note)   |      |
| 03B516                                   | Flash memory control register 1 (FCON1) (Note)   | 128  |
| 03B616                                   | Flash command register (FCMD) (Note)             | 1    |
| 03B716                                   |                                                  |      |
| 03B816                                   |                                                  |      |
| 03B916                                   |                                                  |      |
| 03BA16                                   |                                                  | ]    |
| 03BB <sub>16</sub>                       |                                                  | ] ]  |
| 03BC <sub>16</sub>                       |                                                  | ] ]  |
| 03BD16                                   |                                                  |      |
| 03BE <sub>16</sub>                       |                                                  |      |
| 03BF <sub>16</sub>                       |                                                  |      |

| Addres                                   | s Register                                                          | Page       |
|------------------------------------------|---------------------------------------------------------------------|------------|
| 03C016<br>03C116                         | A-D register 0 (AD0)                                                |            |
| 03C216                                   | A-D register 1 (AD1)                                                |            |
| 03C3 <sub>16</sub><br>03C4 <sub>16</sub> |                                                                     | -          |
| 03C516                                   | A-D register 2 (AD2)                                                |            |
| 03C616<br>03C716                         | A-D register 3 (AD3)                                                |            |
| 03C816                                   | A-D register 4 (AD4)                                                | 93         |
| 03C9 <sub>16</sub><br>03CA <sub>16</sub> |                                                                     | -          |
| 03CB <sub>16</sub>                       | A-D register 5 (AD5)                                                |            |
| 03CC <sub>16</sub><br>03CD <sub>16</sub> | A-D register 6 (AD6)                                                |            |
| 03CE16                                   | A-D register 7 (AD7)                                                |            |
| 03CF <sub>16</sub><br>03D0 <sub>16</sub> | Togistor (NDT)                                                      |            |
| 03D016                                   |                                                                     |            |
| 03D216                                   |                                                                     |            |
| 03D316<br>03D416                         | A-D control register 2 (ADCON2)                                     | 02         |
| 03D416<br>03D516                         | A-D CONTrol register 2 (ADCON2)                                     | 93         |
| 03D616                                   | A-D control register 0 (ADCON0)                                     |            |
| 03D716                                   | A-D control register 1 (ADCON1)                                     | 92         |
| 03D816                                   |                                                                     |            |
| 03D916                                   |                                                                     |            |
| 03DA16                                   |                                                                     |            |
| 03DB <sub>16</sub>                       |                                                                     |            |
| 03DC16                                   |                                                                     | -          |
| 03DD16<br>03DE16                         |                                                                     | -          |
| 03DE16                                   |                                                                     | -          |
| 03E016                                   | Port P0 (P0)                                                        |            |
| 03E116                                   | Port P1 (P1)                                                        | 105        |
| 03E216                                   | Port P0 direction register (PD0)                                    | 101        |
| 03E316                                   | Port P1 direction register (PD1)                                    | 104        |
| 03E416                                   | Port P2 (P2)                                                        | 105        |
| 03E516                                   | Port P3 (P3)                                                        | 105        |
| 03E616                                   | Port P2 direction register (PD2)                                    | 104        |
| 03E716                                   | Port P3 direction register (PD3)                                    | 104        |
| 03E816                                   | Port P4 (P4)                                                        | 105        |
| 03E916                                   | Port P5 (P5)                                                        | 100        |
| 03EA <sub>16</sub><br>03EB <sub>16</sub> | Port P4 direction register (PD4) Port P5 direction register (PD5)   | 104        |
| 03EC16                                   | Port P6 (P6)                                                        | -          |
| 03ED16                                   | Port P7 (P7)                                                        | 105        |
| 03EE16                                   | Port P6 direction register (PD6)                                    |            |
| 03EF16                                   | Port P7 direction register (PD7)                                    | 104        |
| 03F016                                   |                                                                     |            |
| 03F1 <sub>16</sub>                       |                                                                     | 1          |
| 03F216                                   |                                                                     |            |
| 03F3 <sub>16</sub>                       |                                                                     | _          |
| 03F416                                   |                                                                     |            |
| 03F516                                   |                                                                     | <b>」</b>   |
| 03F616                                   |                                                                     | <b>↓</b>   |
| 03F7 <sub>16</sub>                       |                                                                     | <b>⊣</b> ∣ |
| 03F816                                   |                                                                     | -          |
| 03F9 <sub>16</sub>                       |                                                                     | 4          |
| 03FA16                                   |                                                                     | -          |
| 03FB16                                   | Pull-up control register 0 (PLIPO)                                  |            |
| 03FC <sub>16</sub><br>03FD <sub>16</sub> | Pull-up control register 1 (PUR0)                                   | 106        |
| 03FD16<br>03FE16                         | Pull-up control register 1 (PUR1) Pull-up control register 2 (PUR2) | 100        |
| 03FE16                                   | i un up control register 2 (FON2)                                   |            |
| 001 1.10                                 |                                                                     |            |

Note: This register is only exist in flash memory version.

## Chapter 1

Hardware

#### **Description**

The M30201 group of single-chip microcomputers are built using the high-performance silicon gate CMOS process using a M16C/60 Series CPU core. M30201 group is packaged in a 52-pin plastic molded SDIP, or 56-pin plastic molded QFP. These single-chip microcomputers operate using sophisticated instructions featuring a high level of instruction efficiency. With 1M bytes of address space, they are capable of executing instructions at high speed.

The M30201 group includes a wide range of products with different internal memory types and sizes and various package types.

#### **Features**

| Basic machine instructions            | Compatible with the M16C/60 series                                      |
|---------------------------------------|-------------------------------------------------------------------------|
| Memory capacity                       | ROM/RAM (See figure 1.4. ROM expansion.)                                |
| • Shortest instruction execution time | 100ns (f(XIN)=10MHz)                                                    |
| Supply voltage                        | 4.0 to 5.5V (f(XIN)=10MHz) :mask ROM version                            |
|                                       | 2.7 to 5.5V (f(XIN)=7MHz with software one-wait):mask ROM version       |
|                                       | 4.0 to 5.5V (f(XIN)=10MHz) :flash memory version                        |
| Interrupts                            | 9 internal and 3 external interrupt sources, 4 software                 |
|                                       | (including key input interrupt)                                         |
| Multifunction 16-bit timer            | Timer A x 1, timer B x 2, timer X x 3                                   |
| Clock output                          |                                                                         |
| Serial I/O                            | 1 channel for UART or clock synchronous, 1 for UART                     |
| A-D converter                         | 10 bits X 8 channels (Expandable up to 13 channels)                     |
| Watchdog timer                        | 1 line                                                                  |
| Programmable I/O                      |                                                                         |
| LED drive ports                       |                                                                         |
| Clock generating circuit              | 2 built-in clock generation circuits                                    |
|                                       | (built-in feedback resistor, and external ceramic or quartz oscillator) |

#### **Applications**

Home appliances, Audio, office equipment, Automobiles

Specifications written in this manual are believed to be accurate, but are not guaranteed to be entirely free of error.

Specifications in this manual may be changed for functional or performance improvements. Please make sure your manual is the latest edition.

### -----Table of Contents-----

| Central Processing Unit (CPU)12 | Timer 37                   |
|---------------------------------|----------------------------|
| Reset                           |                            |
| Clock Generating Circuit        | A-D Converter78            |
| Protection26                    | Programmable I/O Ports88   |
| Interrupts                      | Electric Characteristics95 |
| Watchdog Timer35                | Flash Memory version126    |

#### **Pin Configuration**

Figures 1.1 to 1.2 show the pin configurations (top view).



Figure 1.1. Pin configuration for the M30201 group (shrink DIP product) (top view)



Figure 1.2. Pin configuration for the M30201 group (QFP product) (top view)

#### **Block Diagram**

Figure 1.3 is a block diagram of the M30201 group.



Figure 1.3. Block diagram for the M30201 group

#### **Performance Outline**

Table 1.1 is performance outline of M30201 group.

Table 1.1. Performance outline of M30201 group

|                              | Item                  | Performance                                               |  |  |
|------------------------------|-----------------------|-----------------------------------------------------------|--|--|
| Number of basic instructions |                       | 91 instructions                                           |  |  |
| Shortest instru              | uction execution time | 100ns (f(XIN)=10MHz                                       |  |  |
| Memory                       | ROM                   | (See figure 4. ROM expansion.)                            |  |  |
| capacity                     | RAM                   | (See figure 4. ROM expansion.) 43 lines                   |  |  |
| I/O port                     | P0 to P7              | 43 lines                                                  |  |  |
| Multifunction                | TA0                   | 16 bits x 1                                               |  |  |
| timer                        | TB0, TB1              | 16 bits x 2                                               |  |  |
|                              | TX0, TX1, TX2         | 16 bits x 3                                               |  |  |
| Serial I/O                   | UART0                 | 16 bits x 2                                               |  |  |
|                              | UART1                 | UART x 1                                                  |  |  |
| A-D converter                |                       | 10 bits x 8 channels (Expandable up to 13 channels)       |  |  |
| Watchdog tim                 | er                    | 15 bits x 1 (with prescaler)                              |  |  |
| Interrupt                    |                       | 9 internal and 3 external sources, 4 software sources     |  |  |
| Clock generating circuit     |                       | 2 built-in clock generation circuits                      |  |  |
|                              |                       | (built-in feedback resistor, and external ceramic or      |  |  |
|                              |                       | quartz oscillator)                                        |  |  |
| Supply voltage               |                       | 4.0 to 5.5V (f(XIN)=10MHz) :mask ROM version              |  |  |
|                              |                       | 2.7 to 5.5V (f(XIN)=7MHz with software one-wait) :mask    |  |  |
|                              |                       | ROM version                                               |  |  |
|                              |                       | 4.0 to 5.5V (f(XIN)=10MHz) :flash memory version          |  |  |
| Power consur                 | nption                | 18mW (f(XIN)=7MHz with software one-wait, Vcc=3V)         |  |  |
|                              |                       | :mask ROM version                                         |  |  |
|                              |                       | 95mW (f(XIN)=10MHz no wait, Vcc=5V) :flash memory version |  |  |
| I/O                          | I/O withstand voltage | 5V                                                        |  |  |
| characteristics              | Output current        | 5mA (15mA:LED drive port)                                 |  |  |
| Device config                | uration               | CMOS silicon gate                                         |  |  |
| Package                      |                       | 52-pin plastic mold SDIP                                  |  |  |
|                              |                       | 56-pin plastic mold QFP                                   |  |  |

Mitsubishi plans to release the following products in the M30201 group:

- (1) Support for mask ROM version and flash memory version
- (2) ROM capacity
- (3) Package

52P4B : Plastic molded SDIP (mask ROM version and flash memory version)56P6S-A : Plastic molded QFP (mask ROM version and flash memory version)

July 1998



Figure 1.4. ROM expansion



Figure 1.5. Type No., memory size, and package

#### **Pin Description**

| Pin name    | Signal name                 | I/O type        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|-----------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Vcc, Vss    | Power supply input          |                 | Supply 2.7 to 5.5 V to the Vcc pin. Supply 0 V to the Vss pin.                                                                                                                                                                                                                                                                                                                                                                                          |
| CNVss       | CNVss                       | Input           | Connect it to the Vss pin.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| RESET       | Reset input                 | Input           | A "L" on this input resets the microcomputer.                                                                                                                                                                                                                                                                                                                                                                                                           |
| XIN<br>XOUT | Clock input<br>Clock output | Input<br>Output | These pins are provided for the main clock generating circuit. Connect a ceramic resonator or crystal between the XIN and the XOUT pins. To use an externally derived clock, input it to the XIN pin and leave the XOUT pin open.                                                                                                                                                                                                                       |
| AVcc        | Analog power supply input   |                 | This pin is a power supply input for the A-D converter. Connect it to Vcc.                                                                                                                                                                                                                                                                                                                                                                              |
| AVss        | Analog power supply input   |                 | This pin is a power supply input for the A-D converter. Connect it to Vss.                                                                                                                                                                                                                                                                                                                                                                              |
| VREF        | Reference voltage input     | Input           | This pin is a reference voltage input for the A-D converter.                                                                                                                                                                                                                                                                                                                                                                                            |
| P00 to P07  | I/O port P0                 | Input/output    | This is an 8-bit CMOS I/O port. It has an input/output port direction register that allows the user to set each pin for input or output individually. When set for input, the user can specify in units of four bits via software whether or not they are tied to a pull-up resistor.                                                                                                                                                                   |
| P10 to P17  | I/O port P1                 | Input/output    | This is an 8-bit I/O port equivalent to P0.                                                                                                                                                                                                                                                                                                                                                                                                             |
| P30 to P35  | I/O port P3                 | Input/output    | This is a 6-bit I/O port equivalent to P0.                                                                                                                                                                                                                                                                                                                                                                                                              |
| P40 to P45  | I/O port P4                 | Input/output    | This is a 6-bit I/O port equivalent to P0. The P40 pin is shared with timer A0 input and serial I/O output TxD1. The P41 pin is shared with timer A0 output. The P42 pin is shared with serial I/O input RxD1. The P43 pin is shared with external interrupt INT0 and timer X0 input/output TX0INOUT. The P44 pin is shared with external interrupt INT1 and timer X1 input/output TX1INOUT. The P45 pin is shared with timer X2 input/output TX2INOUT. |
| P50 to P54  | I/O port P5                 | Input/output    | This is a 5-bit I/O port equivalent to P0. The P50, P51, P52, and P53 pins are shared with serial I/O pins TxD0, RxD0, CLK0, and CLKS. The P54 pin is shared with clock output CLKOUT. Also, these pins are shared with analog input pins AN50 through AN54.                                                                                                                                                                                            |
| P60 to P67  | I/O port P6                 | Input/output    | This is an 8-bit I/O port equivalent to P0. These pins are shared with analog input pins ANo through AN7.                                                                                                                                                                                                                                                                                                                                               |
| P70 to P71  | I/O port P7                 | Input/output    | This is a 2-bit I/O port equivalent to P0 . These pins are used for input/output to and from the oscillator circuit for the clock. Connect a crystal oscillator between the XCIN and the XCOUT pins.                                                                                                                                                                                                                                                    |

#### **Operation of Functional Blocks**

The M30201 accommodates certain units in a single chip. These units include ROM and RAM to store instructions and data and the central processing unit (CPU) to execute arithmetic/logic operations. Also included are peripheral units such as timers, serial I/O, A-D converter, and I/O ports. The following explains each unit.

#### Memory

Figure 1.6 is a memory map of the M30201. The address space extends the 1M bytes from address 0000016 to FFFFF16. From FFFFF16 down is ROM. For example, in the M30201M4-XXXFP, there is 32K bytes of internal ROM from F800016 to FFFFF16. The vector table for fixed interrupts such as the reset are mapped to FFFDC16 to FFFFF16. The starting address of the interrupt routine is stored here. The address of the vector table for timer interrupts, etc., can be set as desired using the internal register (INTB). See the section on interrupts for details.

From 0040016 up is RAM. For example, in the M30201M4-XXXFP, there is 1K byte of internal RAM from 0040016 to 007FF16. In addition to storing data, the RAM also stores the stack used when calling subroutines and when interrupts are generated.

The SFR area is mapped to 0000016 to 003FF16. This area accommodates the control registers for peripheral devices such as I/O ports, A-D converter, serial I/O, and timers, etc. Any part of the SFR area that is not occupied is reserved and cannot be used for other purposes.

The special page vector table is mapped to FFE0016 to FFFDB16. If the starting addresses of subroutines or the destination addresses of jumps are stored here, subroutine call instructions and jump instructions can be used as 2-byte instructions, reducing the number of program steps.



Figure 1.6. Memory map



Figure 1.7. Location of peripheral unit control registers (1)



Figure 1.8. Location of peripheral unit control registers (2)



#### **Central Processing Unit (CPU)**

The CPU has a total of 13 registers shown in Figure 1.9. Seven of these registers (R0, R1, R2, R3, A0, A1, and FB) come in two sets; therefore, these have two register banks.



Figure 1.9. Central processing unit register

#### (1) Data registers (R0, R0H, R0L, R1, R1H, R1L, R2, and R3)

Data registers (R0, R1, R2, and R3) are configured with 16 bits, and are used primarily for transfer and arithmetic/logic operations.

Registers R0 and R1 each can be used as separate 8-bit data registers, high-order bits as (R0H, R1H), and low-order bits as (R0L, R1L). In some instructions, registers R2 and R0, as well as R3 and R1 can use as 32-bit data registers (R2R0, R3R1).

#### (2) Address registers (A0 and A1)

Address registers (A0 and A1) are configured with 16 bits, and have functions equivalent to those of data registers. These registers can also be used for address register indirect addressing and address register relative addressing.

In some instructions, registers A1 and A0 can be combined for use as a 32-bit address register (A1A0).



#### (3) Frame base register (FB)

Frame base register (FB) is configured with 16 bits, and is used for FB relative addressing.

#### (4) Program counter (PC)

Program counter (PC) is configured with 20 bits, indicating the address of an instruction to be executed.

#### (5) Interrupt table register (INTB)

Interrupt table register (INTB) is configured with 20 bits, indicating the start address of an interrupt vector table.

#### (6) Stack pointer (USP/ISP)

Stack pointer comes in two types: user stack pointer (USP) and interrupt stack pointer (ISP), each configured with 16 bits.

Your desired type of stack pointer (USP or ISP) can be selected by a stack pointer select flag (U flag). This flag is located at the position of bit 7 in the flag register (FLG).

#### (7) Static base register (SB)

Static base register (SB) is configured with 16 bits, and is used for SB relative addressing.

#### (8) Flag register (FLG)

Flag register (FLG) is configured with 11 bits, each bit is used as a flag. Figure 1.10 shows the flag register (FLG). The following explains the function of each flag:

#### • Bit 0: Carry flag (C flag)

This flag retains a carry, borrow, or shift-out bit that has occurred in the arithmetic/logic unit.

#### • Bit 1: Debug flag (D flag)

This flag enables a single-step interrupt.

When this flag is "1", a single-step interrupt is generated after instruction execution. This flag is cleared to "0" when the interrupt is acknowledged.

#### • Bit 2: Zero flag (Z flag)

This flag is set to "1" when an arithmetic operation resulted in 0; otherwise, cleared to "0".

#### • Bit 3: Sign flag (S flag)

This flag is set to "1" when an arithmetic operation resulted in a negative value; otherwise, cleared to "0".

#### • Bit 4: Register bank select flag (B flag)

This flag chooses a register bank. Register bank 0 is selected when this flag is "0"; register bank 1 is selected when this flag is "1".

#### Bit 5: Overflow flag (O flag)

This flag is set to "1" when an arithmetic operation resulted in overflow; otherwise, cleared to "0".

#### Bit 6: Interrupt enable flag (I flag)

This flag enables a maskable interrupt.

An interrupt is disabled when this flag is "0", and is enabled when this flag is "1". This flag is cleared to "0" when the interrupt is acknowledged.



#### • Bit 7: Stack pointer select flag (U flag)

Interrupt stack pointer (ISP) is selected when this flag is "0"; user stack pointer (USP) is selected when this flag is "1".

This flag is cleared to "0" when a hardware interrupt is acknowledged or an INT instruction of software interrupt Nos. 0 to 31 is executed.

#### • Bits 8 to 11: Reserved area

#### • Bits 12 to 14: Processor interrupt priority level (IPL)

Processor interrupt priority level (IPL) is configured with three bits, for specification of up to eight processor interrupt priority levels from level 0 to level 7.

If a requested interrupt has priority greater than the processor interrupt priority level (IPL), the interrupt is enabled.

#### • Bit 15: Reserved area

The C, Z, S, and O flags are changed when instructions are executed. See the software manual for details.



Figure 1.10. Flag register (FLG)

#### Reset

There are two kinds of resets; hardware and software. In both cases, operation is the same after the reset. (See "Software Reset" for details of software resets.) This section explains on hardware resets.

When the supply voltage is in the range where operation is guaranteed, a reset is effected by holding the reset pin level "L" (0.2Vcc max.) for at least 20 cycles. When the reset pin level is then returned to the "H" level while main clock is stable, the reset status is cancelled and program execution resumes from the address in the reset vector table.

Figure 1.11 shows the example reset circuit. Figure 1.12 shows the reset sequence.



Figure 1.11. Example reset circuit



Figure 1.12. Reset sequence



Figure 1.13. Device's internal status after a reset is cleared

#### **Software Reset**

Writing "1" to bit 3 of the processor mode register 0 (address 000416) applies a (software) reset to the microcomputer. A software reset has almost the same effect as a hardware reset. The contents of internal RAM are preserved.

Figure 1.14 shows the processor mode register 0 and 1.



Figure 1.14. Processor mode register 0 and 1.

#### Software wait

The wait bit (bit 7) of the processor mode register 1 (address 000516)(note) allows you to insert software wait states for the internal ROM/RAM areas. If this bit is 0, the bus cycle is executed in one BCLK (internal clock) period; if the bit is 1, the bus cycle is executed in two BCLK periods. This bit is cleared to 0 after a reset.

The SFR area is unaffected by this control bit; it is always accessed in two BCLK periods.

Table 1.2 shows the relationship between software wait states and bus cycles.

Note: Before attempting to change the contents of the processor mode register 1, set bit 1 of the protect register (address 000A<sub>16</sub>) to "1".

Table 1.2. Software waits and bus cycles

| Area     | Wait bit | Bus cycle     |
|----------|----------|---------------|
| SFR      | Invalid  | 2 BCLK cycles |
| Internal | 0        | 1 BCLK cycle  |
| ROM/RAM  | 1        | 2 BCLK cycles |

#### **Clock Generating Circuit**

The clock generating circuit contains two oscillator circuits that supply the operating clock sources to the CPU and internal peripheral units.

Table 1.3. Main clock and sub-clock generating circuits

|                                           | Main clock generating circuit         | Sub clock generating circuit |  |
|-------------------------------------------|---------------------------------------|------------------------------|--|
| Use of clock                              | CPU's operating clock source          | CPU's operating clock source |  |
|                                           | Internal peripheral units'            | Timer A/B/X's count clock    |  |
|                                           | operating clock source                | source                       |  |
| Usable oscillator                         | Ceramic or crystal oscillator         | Crystal oscillator           |  |
| Pins to connect oscillator                | XIN, XOUT                             | Xcin, Xcout                  |  |
| Oscillation stop/restart function         | Available                             | Available                    |  |
| Oscillator status immediately after reset | Oscillating                           | Stopped                      |  |
| Other                                     | Externally derived clock can be input |                              |  |

#### **Example of oscillator circuit**

Figure 1.15 shows some examples of the main clock circuit, one using an oscillator connected to the circuit, and the other one using an externally derived clock for input. Figure 1.16 shows some examples of subclock circuits, one using an oscillator connected to the circuit, and the other one using an externally derived clock for input. Circuit constants in Figures 15 and 16 vary with each oscillator used. Use the values recommended by the manufacturer of your oscillator.



Figure 1.15. Examples of main clock



Figure 1.16. Examples of sub-clock

#### **Clock Control**

Figure 1.17 shows the block diagram of the clock generating circuit.



Figure 1.17. Clock generating circuit

The following paragraphs describes the clocks generated by the clock generating circuit.

#### (1) Main clock

The main clock is generated by the main clock oscillation circuit. After a reset, the clock is divided by 8 to BCLK. The clock can be stopped using the main clock stop bit (bit 5 at address 000616). Stopping the clock, after switching the operating clock source of CPU to the sub-clock, reduces the power dissipation. After the oscillation of the main clock oscillation circuit has stabilized, the drive capacity of the main clock oscillation circuit can be reduced using the XIN-XOUT drive capacity select bit (bit 5 at address 000716). Reducing the drive capacity of the main clock oscillation circuit reduces the power dissipation. This bit changes to "1" when shifting from high-speed/medium-speed mode to stop mode and at a reset. When shifting from low-speed/low power dissipation mode to stop mode, the value before stop mode is retained.

#### (2) Sub-clock

The sub-clock is generated by the sub-clock oscillation circuit. No sub-clock is generated after a reset. After oscillation is started using the port Xc select bit (bit 4 at address 0006<sub>16</sub>), the sub-clock can be selected as BCLK by using the system clock select bit (bit 7 at address 0006<sub>16</sub>). However, be sure that the sub-clock oscillation has fully stabilized before switching.

After the oscillation of the sub-clock oscillation circuit has stabilized, the drive capacity of the sub-clock oscillation circuit can be reduced using the XCIN-XCOUT drive capacity select bit (bit 3 at address 000616). Reducing the drive capacity of the sub-clock oscillation circuit reduces the power dissipation. This bit changes to "1" when shifting to stop mode and at a reset.

#### (3) **BCLK**

The BCLK is the clock that drives the CPU, and is fc or the clock is derived by dividing the main clock by 1, 2, 4, 8, or 16. The BCLK is derived by dividing the main clock by 8 after a reset.

The main clock division select bit 0(bit 6 at address 000616) changes to "1" when shifting from high-speed/medium-speed to stop mode and at reset. When shifting from low-speed/low power dissipation mode to stop mode, the value before stop mode is retained.

#### (4) Peripheral function clock (f1, f8, f32, fAD)

The clock for the peripheral devices is derived from the main clock or by dividing it by 8 or 32. The peripheral function clock is stopped by stopping the main clock or by setting the WAIT peripheral function clock stop bit (bit 2 at 000616) to "1" and then executing a WAIT instruction.

#### (5) fC32

This clock is derived by dividing the sub-clock by 32. It is used for the timer A, timer B and timer X counts.

#### (6) fc

This clock has the same frequency as the sub-clock. It is used for BCLK and for the watchdog timer.

Figure 1.18 shows the system clock control registers 0 and 1.

| 07 b6 b5 b4 | 4 b3 b2 b1 b0 | Symbol<br>CM0                                 | Address<br>000616                           | When reset<br>4816                                                                                              |    |
|-------------|---------------|-----------------------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------|----|
|             |               | Bit symbol                                    | Bit name                                    | Function                                                                                                        | RV |
|             |               | CM00                                          | Clock output function select bit            | 0 0 : I/O port P54<br>0 1 : fc output                                                                           | 0  |
|             |               | CM01                                          |                                             | 1 0 : f8 output<br>1 1 : Clock divide counter output                                                            | 0  |
|             |               | CM02                                          | WAIT peripheral function clock stop bit     | 0 : Do not stop peripheral function clock in wait mode 1 : Stop peripheral function clock in wait mode (Note 8) | 0  |
|             | CM03          | XCIN-XCOUT drive capacity select bit (Note 2) | 0 : LOW<br>1 : HIGH                         | 0                                                                                                               |    |
|             |               | CM04                                          | Port Xc select bit                          | 0: I/O port<br>1: Xcin-Xcout generation                                                                         | 0  |
|             |               | CM05                                          | Main clock (XIN-XOUT) stop bit (Note 3,4,5) | 0 : On<br>1 : Off                                                                                               | 0  |
|             |               | CM06                                          | Main clock division select bit 0 (Note 7)   | 0 : CM16 and CM17 valid<br>1 : Division by 8 mode                                                               | 0  |
|             |               | CM07                                          | System clock select bit (Note 6)            | 0 : XIN, XOUT<br>1 : XCIN, XCOUT                                                                                | 0  |

- Note 1: Set bit 0 of the protect register (address 000A16) to "1" before writing to this register.
- Note 2: Changes to "1" when shifting to stop mode and at a reset.
- Note 3: This bit is used to stop the main clock when placing the device in a low-power mode. If you want to operate with XIN after exiting from the stop mode, set this bit to "0". When operating with a self-excited oscillator, set the system clock select bit (CM07) to "1" before setting this bit to "1".
- Note 4: When inputting external clock, only clock oscillation buffer is stopped and clock input is acceptable.
- Note 5: If this bit is set to "1", XOUT turns "H". The built-in feedback resistor remains being connected, so XIN turns pulled up to XOUT ("H") via the feedback resistor.
- Note 6: Set port Xc select bit (CM04) to "1" and stabilize the sub-clock oscillating before setting to this bit from "0" to "1".

  Do not write to both bits at the same time. And also, set the main clock stop bit (CM05) to "0" and stabilize the main clock oscillating before setting this bit from "1" to "0".
- Note 7: This bit changes to "1" when shifting from high-speed/medium-speed mode to stop mode and at a reset. When shifting from low-speed/low power dissipation mode to stop mode, the value before stop mode is retained.
- Note 8: fc32 is not included.

#### System clock control register 1 (Note 1)



Note 1: Set bit 0 of the protect register (address 000A16) to "1" before writing to this register.

Note 2: This bit changes to "1" when shifting from high-speed/medium-speed mode to stop mode and at a reset. When shifting from low-speed/low power dissipation mode to stop mode, the value before stop mode is retained.

Note 3: Can be selected when bit 6 of the system clock control register 0 (address 000616) is "0". If "1", division mode is fixed at 8. Note 4: If this bit is set to "1", XOUT turns "H", and the built-in feedback resistor is cut off. XCIN and XCOUT turn high-impedance state.

Figure 1.18. Clock control registers 0 and 1

# **Clock Output**

The clock output function select bit allows you to choose the clock from f8, fc, or a divide-by-n clock that is output from the P54/CKOUT pin. The clock divide counter is an 8-bit counter whose count source is f32, and its divide ratio can be set in the range of 0016 to FF16. Figure 1.19 shows a block diagram of clock output.



Figure 1.19. Block diagram of clock output



#### **Stop Mode**

Writing "1" to the all-clock stop control bit (bit 0 at address 000716) stops all oscillation and the microcomputer enters stop mode. In stop mode, the content of the internal RAM is retained provided that Vcc remains above 2V.

Because the oscillation of BCLK, f1 to f32, fc, fc32, and fAD stops in stop mode, peripheral functions such as the A-D converter and watchdog timer do not function. However, timer A, timer B and timer X operate provided that the event counter mode is set to an external pulse, and UART0 functions provided an external clock is selected. Table 1.4 shows the status of the ports in stop mode.

Stop mode is cancelled by a hardware reset or an interrupt. If an interrupt is to be used to cancel stop mode, that interrupt must first have been enabled. If returning by an interrupt, that interrupt routine is executed. When shifting from high-speed/medium-speed mode to stop mode and at a reset, the main clock division select bit 0 (bit 6 at address 000616) is set to "1". When shifting from low-speed/low power dissipation mode to stop mode, the value before stop mode is retained.

Table 1.4. Port status during stop mode

| Pin    |                         | States                          |
|--------|-------------------------|---------------------------------|
| Port   |                         | Retains status before stop mode |
| СЬКОИТ | When fc selected        | "H"                             |
|        | When f8, clock devided  | Retains status before stop mode |
|        | counter output selected |                                 |

#### **Wait Mode**

When a WAIT instruction is executed, BCLK stops and the microcomputer enters the wait mode. In this mode, oscillation continues but BCLK and watchdog timer stop. Writing "1" to the WAIT peripheral function clock stop bit and executing a WAIT instruction stops the clock being supplied to the internal peripheral functions, allowing power dissipation to be reduced. Table 1.5 shows the status of the ports in wait mode. Wait mode is cancelled by a hardware reset or interrupt. If an interrupt is used to cancel wait mode, the microcomputer restarts from the interrupt routine using as BCLK, the clock that had been selected when the WAIT instruction was executed.

Table 1.5. Port status during wait mode

|      | Pin                                            | States                                                                                                                                                                                           |
|------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port |                                                | Retains status before wait mode                                                                                                                                                                  |
| СЬКО | When fc selected                               | Does not stop                                                                                                                                                                                    |
|      | When f8, clock devided counter output selected | Does not stop when the WAIT peripheral function clock stop bit is "0". When the WAIT peripheral function clock stop bit is "1",the status immediately prior to entering wait mode is maintained. |

#### Status Transition of BCLK

Power dissipation can be reduced and low-voltage operation achieved by changing the count source for BCLK. Table 1.6 shows the operating modes corresponding to the settings of system clock control registers 0 and 1.

When reset, the device starts in division by 8 mode. The main clock division select bit 0(bit 6 at address 000616) changes to "1" when shifting from high-speed/medium-speed to stop mode and at a reset. When shifting from low-speed/low power dissipation mode to stop mode, the value before stop mode is retained. The following shows the operational modes of BCLK.

### (1) Division by 2 mode

The main clock is divided by 2 to obtain the BCLK.

### (2) Division by 4 mode

The main clock is divided by 4 to obtain the BCLK.

### (3) Division by 8 mode

The main clock is divided by 8 to obtain the BCLK. When reset, the device starts operating from this mode. Before the user can go from this mode to no division mode, division by 2 mode, or division by 4 mode, the main clock must be oscillating stably. When going to low-speed or lower power consumption mode, make sure the sub-clock is oscillating stably.

### (4) Division by 16 mode

The main clock is divided by 16 to obtain the BCLK.

# (5) No-division mode

The main clock is divided by 1 to obtain the BCLK.

#### (6) Low-speed mode

fc is used as BCLK. Note that oscillation of both the main and sub-clocks must have stabilized before transferring from this mode to another or vice versa. At least 2 to 3 seconds are required after the sub-clock starts. Therefore, the program must be written to wait until this clock has stabilized immediately after powering up and after stop mode is cancelled.

#### (7) Low power dissipation mode

fc is the BCLK and the main clock is stopped.

Note: Before the count source for BCLK can be changed from XIN to XCIN or vice versa, the clock to which the count source is going to be switched must be oscillating stably. Allow a wait time in software for the oscillation to stabilize before switching over the clock.

Table 1.6. Operating modes dictated by settings of system clock control registers 0 and 1

| CM17    | CM16    | CM07 | CM06    | CM05 | CM04    | Operating mode of BCLK     |  |
|---------|---------|------|---------|------|---------|----------------------------|--|
| 0       | 1       | 0    | 0       | 0    | Invalid | Division by 2 mode         |  |
| 1       | 0       | 0    | 0       | 0    | Invalid | Division by 4 mode         |  |
| Invalid | Invalid | 0    | 1       | 0    | Invalid | Division by 8 mode         |  |
| 1       | 1       | 0    | 0       | 0    | Invalid | Division by 16 mode        |  |
| 0       | 0       | 0    | 0       | 0    | Invalid | No-division mode           |  |
| Invalid | Invalid | 1    | Invalid | 0    | 1       | Low-speed mode             |  |
| Invalid | Invalid | 1    | Invalid | 1    | 1       | Low power dissipation mode |  |



### **Power Saving**

There are three power save modes.

### (1) Normal operating mode

#### • High-speed mode

In this mode, one main clock cycle forms BCLK. The CPU operates on the BCLK. The peripheral functions operate on the clocks specified for each respective function.

#### • Medium-speed mode

In this mode, the main clock is divided into 2, 4, 8, or 16 to form BCLK. The CPU operates on the BCLK. The peripheral functions operated on the clocks specified for each respective function.

#### Low-speed mode

In this mode, fc forms BCLK. The CPU operates on the fc clock. fc is the clock supplied by the subclock. The peripheral functions operate on the clocks specified for each respective function.

#### Low power-dissipation mode

This mode is selected when the main clock is stopped from low-speed mode. The CPU operates on the fc clock. fc is the clock supplied by the subclock. Only the peripheral functions for which the subclock was selected as the count source continue to run.

#### (2) Wait mode

CPU operation is halted in this mode. The oscillator continues to run.

#### (3) Stop mode

All oscillators stop in this mode. The CPU and internal peripheral functions all stop. Of all 3 power saving modes, power savings are greatest in this mode.

Figure 1.20 shows the transition between each of the three modes, (1), (2), and (3).



Figure 1.20. Clock transition

#### **Protection**

The protection function is provided so that the values in important registers cannot be changed in the event that the program runs out of control. Figure 1.21 shows the protect register. The values in the processor mode register 0 (address 000416), processor mode register 1 (address 000516), system clock control register 0 (address 000616), system clock control register 1 (address 000716) and port P4 direction register (address 03EA16) can only be changed when the respective bit in the protect register is set to "1". Therefore, important outputs can be allocated to port P4.

If, after "1" (write-enabled) has been written to the port P4 direction register write-enable bit (bit 2 at address 000A16), a value is written to any address, the bit automatically reverts to "0" (write-inhibited). However, the system clock control registers 0 and 1 write-enable bit (bit 0 at 000A16) and processor mode register 0 and 1 write-enable bit (bit 1 at 000A16) do not automatically return to "0" after a value has been written to an address. The program must therefore be written to return these bits to "0".



Figure 1.21. Protect register

### **Overview of Interrupt**

# Type of Interrupts

Figure 1.22 lists the types of interrupts.



Figure 1.22. Classification of interrupts

• Maskable interrupt : An interrupt which can be enabled (disabled) by the interrupt enable flag (I

flag) or whose interrupt priority can be changed by priority level.

• Non-maskable interrupt : An interrupt which cannot be enabled (disabled) by the interrupt enable flag

(I flag) or whose interrupt priority cannot be changed by priority level.



### **Software Interrupts**

A software interrupt occurs when executing certain instructions. Software interrupts are non-maskable interrupts.

### Undefined instruction interrupt

An undefined instruction interrupt occurs when executing the UND instruction.

### Overflow interrupt

An overflow interrupt occurs when executing the INTO instruction with the overflow flag (O flag) set to "1". The following are instructions whose O flag changes by arithmetic:

ABS, ADC, ADCF, ADD, CMP, DIV, DIVU, DIVX, NEG, RMPA, SBB, SHA, SUB

#### BRK interrupt

A BRK interrupt occurs when executing the BRK instruction.

#### INT interrupt

An INT interrupt occurs when assigning one of software interrupt numbers 0 through 63 and executing the INT instruction. Software interrupt numbers 0 through 31 are assigned to peripheral I/O interrupts, so executing the INT instruction allows executing the same interrupt routine that a peripheral I/O interrupt does.

The stack pointer (SP) used for the INT interrupt is dependent on which software interrupt number is involved.

So far as software interrupt numbers 0 through 31 are concerned, the microcomputer saves the stack pointer assignment flag (U flag) when it accepts an interrupt request. If change the U flag to "0" and select the interrupt stack pointer (ISP), and then execute an interrupt sequence. When returning from the interrupt routine, the U flag is returned to the state it was before the acceptance of interrupt request. So far as software numbers 32 through 63 are concerned, the stack pointer does not make a shift.



### **Hardware Interrupts**

Hardware interrupts are classified into two types — special interrupts and peripheral I/O interrupts.

### (1) Special interrupts

Special interrupts are non-maskable interrupts.

#### Reset

Reset occurs if an "L" is input to the RESET pin.

#### DBC interrupt

This interrupt is exclusively for the debugger, do not use it in other circumstances.

#### Watchdog timer interrupt

Generated by the watchdog timer.

#### Single-step interrupt

This interrupt is exclusively for the debugger, do not use it in other circumstances. With the debug flag (D flag) set to "1", a single-step interrupt occurs after one instruction is executed.

#### Address match interrupt

An address match interrupt occurs immediately before the instruction held in the address indicated by the address match interrupt register is executed with the address match interrupt enable bit set to "1". If an address other than the first address of the instruction in the address match interrupt register is set, no address match interrupt occurs.

### (2) Peripheral I/O interrupts

A peripheral I/O interrupt is generated by one of built-in peripheral functions. The interrupt vector table is the same as the one for software interrupt numbers 0 through 31 the INT instruction uses. Peripheral I/O interrupts are maskable interrupts.

#### Key-input interrupt

A key-input interrupt occurs if an "L" is input to the KI pin.

#### A-D conversion interrupt

This is an interrupt that the A-D converter generates.

#### UART0 and UART1 transmission interrupt

These are interrupts that the serial I/O transmission generates.

### UART0 and UART1 reception interrupt

These are interrupts that the serial I/O reception generates.

#### • Timer A0 interrupt

This is an interrupts that timer A0 generates.

### • Timer B0 and timer B2 interrupt

These are interrupts that timer B generates.

#### Timer X0 to timer X2 interrupt

These are interrupts that timer X generates.

#### • INTO and INT1 interrupt

An INT interrupt occurs if either a rising edge or a falling edge is input to the INT pin.



### **Interrupts and Interrupt Vector Tables**

If an interrupt request is accepted, a program branches to the interrupt routine set in the interrupt vector table. Set the first address of the interrupt routine in each vector table. Figure 1.23 shows format for specifying interrupt vector addresses.

Two types of interrupt vector tables are available — fixed vector table in which addresses are fixed and variable vector table in which addresses can be varied by the setting.



Figure 1.23. Format for specifying interrupt vector addresses

#### Fixed vector tables

The fixed vector table is a table in which addresses are fixed. The vector tables are located in an area extending from FFFDC16 to FFFFF16. One vector table comprises four bytes. Set the first address of interrupt routine in each vector table. Table 1.7 shows the interrupts assigned to the fixed vector tables and addresses of vector tables.

Table 1.7. Interrupt and fixed vector address

| Interrupt source      | Vector table addresses                     | Remarks                                                          |
|-----------------------|--------------------------------------------|------------------------------------------------------------------|
|                       | Address (L) to address (H)                 |                                                                  |
| Undefined instruction | FFFDC <sub>16</sub> to FFFDF <sub>16</sub> | Interrupt on UND instruction                                     |
| Overflow              | FFFE0 <sub>16</sub> to FFFE3 <sub>16</sub> | Interrupt on INTO instruction                                    |
| BRK instruction       | FFFE4 <sub>16</sub> to FFFE7 <sub>16</sub> | If the vector is filled with FF16, program execution starts from |
|                       |                                            | the address shown by the vector in the variable vector table     |
| Address match         | FFFE816 to FFFEB16                         | There is an address-matching interrupt enable bit                |
| Single step (Note)    | FFFEC <sub>16</sub> to FFFEF <sub>16</sub> | Do not use                                                       |
| Watchdog timer        | FFFF0 <sub>16</sub> to FFFF3 <sub>16</sub> |                                                                  |
| DBC (Note)            | FFFF4 <sub>16</sub> to FFFF7 <sub>16</sub> | Do not use                                                       |
| -                     | FFFF8 <sub>16</sub> to FFFFB <sub>16</sub> | -                                                                |
| Reset                 | FFFFC <sub>16</sub> to FFFF <sub>16</sub>  |                                                                  |

Note: Interrupts used for debugging purposes only.



#### Variable vector tables

The addresses in the variable vector table can be modified, according to the user's settings. Indicate the first address using the interrupt table register (INTB). The 256-byte area subsequent to the address the INTB indicates becomes the area for the variable vector tables. One vector table comprises four bytes. Set the first address of the interrupt routine in each vector table. Table 1.8 shows the interrupts assigned to the variable vector tables and addresses of vector tables.

Table 1.8. Interrupt causes (variable interrupt vector addresses)

| Software interrupt number          | Vector table address<br>Address (L) to address (H) | Interrupt source    | Remarks                    |
|------------------------------------|----------------------------------------------------|---------------------|----------------------------|
| Software interrupt number 0        | +0 to +3 (Note)                                    | BRK instruction     | Cannot be masked by I flag |
|                                    |                                                    |                     |                            |
| Software interrupt number 11       | +44 to +47 (Note)                                  |                     |                            |
| Software interrupt number 12       | +48 to +51 (Note)                                  |                     |                            |
| Software interrupt number 13       | +52 to +55 (Note)                                  | Key input interrupt |                            |
| Software interrupt number 14       | +56 to +59 (Note)                                  | A-D                 |                            |
|                                    |                                                    |                     |                            |
| Software interrupt number 17       | +68 to +71 (Note)                                  | UART0 transmit      |                            |
| Software interrupt number 18       | +72 to +75 (Note)                                  | UART0 receive       |                            |
| Software interrupt number 19       | +76 to +79 (Note)                                  | UART1 transmit      |                            |
| Software interrupt number 20       | +80 to +83 (Note)                                  | UART1 receive       |                            |
| Software interrupt number 21       | +84 to +87 (Note)                                  | Timer A0            |                            |
| Software interrupt number 22       | +88 to +91 (Note)                                  | Timer X0            |                            |
| Software interrupt number 23       | +92 to +95 (Note)                                  | Timer X1            |                            |
| Software interrupt number 24       | +96 to +99 (Note)                                  | Timer X2            |                            |
| Software interrupt number 25       | +100 to +103 (Note)                                |                     |                            |
| Software interrupt number 26       | +104 to +107 (Note)                                | Timer B0            |                            |
| Software interrupt number 27       | +108 to +111 (Note)                                | Timer B1            |                            |
| Software interrupt number 28       | +112 to +115 (Note)                                |                     |                            |
| Software interrupt number 29       | +116 to +119 (Note)                                | INT0                |                            |
| Software interrupt number 30       | +120 to +123 (Note)                                | ĪNT1                |                            |
| Software interrupt number 31       | +124 to +127 (Note)                                |                     |                            |
| Software interrupt number 32       | +128 to +131 (Note)                                |                     |                            |
| to<br>Software interrupt number 63 | to<br>+252 to +255 (Note)                          | Software interrupt  | Cannot be masked by I flag |

Note: Address relative to address in interrupt table register (INTB).



### **Interrupt Control**

Descriptions are given here regarding how to enable or disable maskable interrupts and how to set the priority to be accepted. What is described here does not apply to non-maskable interrupts.

Enable or disable a maskable interrupt using the interrupt enable flag (I flag), interrupt priority level select bit, and processor interrupt priority level (IPL). Whether an interrupt request is present or absent is indicated by the interrupt request bit. The interrupt request bit and the interrupt priority level selection bit are located in the interrupt control register of each interrupt. Also, the interrupt enable flag (I flag) and the IPL are located in the flag register (FLG).

Figure 1.24 shows the interrupt control registers.



Figure 1.24. Interrupt control register



### Interrupt Enable Flag

The interrupt enable flag (I flag) controls the enabling and disabling of maskable interrupts. Setting this flag to "1" enables all maskable interrupts; setting it to "0" disables all maskable interrupts. This flag is set to "0" after reset.

#### **Interrupt Request Bit**

The interrupt request bit is set to "1" by hardware when an interrupt is requested. After the interrupt is accepted and jumps to the corresponding interrupt vector, the request bit is set to "0" by hardware. The interrupt request bit can also be set to "0" by software. (Do not set this bit to "1").

### Interrupt Priority Level Select Bit and Processor Interrupt Priority Level (IPL)

Set the interrupt priority level using the interrupt priority level select bit, which is one of the component bits of the interrupt control register. When an interrupt request occurs, the interrupt priority level is compared with the IPL. The interrupt is enabled only when the priority level of the interrupt is higher than the IPL. Therefore, setting the interrupt priority level to "0" disables the interrupt.

Table 1.9 shows the settings of interrupt priority levels and Table 1.10 shows the interrupt levels enabled, according to the consist of the IPL.

The following are conditions under which an interrupt is accepted:

- · interrupt enable flag (I flag) = 1
- · interrupt request bit = 1
- · interrupt priority level > IPL

The interrupt enable flag (I flag), the interrupt request bit, the interrupt priority select bit, and the IPL are independent, and they are not affected by one another.

Table 1.9. Settings of interrupt priority levels

|         |         | priority<br>ect bit | Interrupt priority<br>level  | Priority<br>order |
|---------|---------|---------------------|------------------------------|-------------------|
| b2<br>0 | b1<br>0 | b0<br>0             | Level 0 (interrupt disabled) |                   |
| 0       | 0       | 1                   | Level 1                      | Low               |
| 0       | 1       | 0                   | Level 2                      |                   |
| 0       | 1       | 1                   | Level 3                      |                   |
| 1       | 0       | 0                   | Level 4                      |                   |
| 1       | 0       | 1                   | Level 5                      |                   |
| 1       | 1       | 0                   | Level 6                      |                   |
| 1       | 1       | 1                   | Level 7                      | High              |

Table 1.10. Interrupt levels enabled according to the contents of the IPL

| IPL   |       | -     | Enabled interrupt priority levels        |
|-------|-------|-------|------------------------------------------|
| IPI 2 | IPI 1 | IPI o |                                          |
| 0     | 0     | 0     | Interrupt levels 1 and above are enabled |
| 0     | 0     | 1     | Interrupt levels 2 and above are enabled |
| 0     | 1     | 0     | Interrupt levels 3 and above are enabled |
| 0     | 1     | 1     | Interrupt levels 4 and above are enabled |
| 1     | 0     | 0     | Interrupt levels 5 and above are enabled |
| 1     | 0     | 1     | Interrupt levels 6 and above are enabled |
| 1     | 1     | 0     | Interrupt levels 7 and above are enabled |
| 1     | 1     | 1     | All maskable interrupts are disabled     |



### **Changing the Interrupt Control Register**

#### < Program examples >

The program examples are described as follow:

Example 1:

INT SWITCH1:

FCLR I ; Disable interrupts.

AND.B #00h, 0055h ; Clear TA0IC int. priority level and int. request bit.

NOP ; Four NOP instructions are required when using HOLD function.

NOP

FSET I ; Enable interrupts.

Example 2:

INT\_SWITCH2:

FCLR I ; Disable interrupts.

AND.B #00h, 0055h ; Clear TA0IC int. priority level and int. request bit.

MOV.W MEM, R0 ; Dummy read. FSET I ; Enable interrupts.

Example 3:

INT\_SWITCH3:

PUSHC FLG ; Push Flag register onto stack

FCLR I ; Disable interrupts.

AND.B #00h, 0055h ; Clear TA0IC int. priority level and int. request bit.

POPC FLG ; Enable interrupts.

The reason why two NOP instructions or dummy read are inserted before FSET I in Examples 1 and 2 is to prevent the interrupt enable flag I from being set before the interrupt control register is rewritten due to effects of the instruction queue.

If changing the interrupt control register using an instruction other than the instructions listed hear, and if an interrupt occurs associated with this register during execution of the instruction, there can be instances in which the interrupt request bit is not set. To avoid this problem, use one of the instructions given below to change the register.

Following instructions: AND, OR, BCLR or BSET



#### Interrupt Sequence

An interrupt sequence — what are performed over a period from the instant an interrupt is accepted to the instant the interrupt routine is executed — is described here.

If an interrupt occurs during execution of an instruction, the processor determines its priority when the execution of the instruction is completed, and transfers control to the interrupt sequence from the next cycle. If an interrupt occurs during execution of either the SMOVB, SMOVF, SSTR or RMPA instruction, the processor temporarily suspends the instruction being executed, and transfers control to the interrupt sequence.

In the interrupt sequence, the processor carries out the following in sequence given:

- (1) CPU gets the interrupt information (the interrupt number and interrupt request level) by reading address 0000016. After this, the corresponding interrupt request bit becomes "0".
- (2) Saves the content of the flag register (FLG) as it was immediately before the start of interrupt sequence in the temporary register (Note) within the CPU.
- (3) Sets the interrupt enable flag (I flag), the debug flag (D flag), and the stack pointer select flag (U flag) to "0" (the U flag, however, does not change if the INT instruction, in software interrupt numbers 32 through 63, is executed).
- (4) Saves the content of the temporary register (Note) within the CPU in the stack area.
- (5) Saves the content of the program counter (PC) in the stack area.
- (6) Sets the interrupt priority level of the accepted instruction in the IPL.

After the interrupt sequence is completed, the processor resumes executing instructions from the first address of the interrupt routine.

Note: This register cannot be utilized by the user.

#### **Interrupt Response Time**

'Interrupt response time' is the period between the instant an interrupt occurs and the instant the first instruction within the interrupt routine has been executed. This time comprises the period from the occurrence of an interrupt to the completion of the instruction under execution at that moment (a) and the time required for executing the interrupt sequence (b). Figure 1.25 shows the interrupt response time.



Figure 1.25. Interrupt response time



Time (a) is dependent on the instruction under execution. Thirty cycles is the maximum required for the DIVX instruction (without wait).

Time (b) is as shown in Table 1.11.

Table 1.11. Time required for executing the interrupt sequence

| Interrupt vector address | Stack pointer (SP) value | 16-bit bus, without wait | 8-bit bus, without wait |
|--------------------------|--------------------------|--------------------------|-------------------------|
| Even                     | Even                     | 18 cycles (Note 1)       | 20 cycles (Note 1)      |
| Even                     | Odd                      | 19 cycles (Note 1)       | 20 cycles (Note 1)      |
| Odd (Note 2)             | Even                     | 19 cycles (Note 1)       | 20 cycles (Note 1)      |
| Odd (Note 2)             | Odd                      | 20 cycles (Note 1)       | 20 cycles (Note 1)      |

Note 1: Add 2 cycles in the case of a DBC interrupt; add 1 cycle in the case either of an address match interrupt or of a single-step interrupt.

Note 2: Locate an interrupt vector address in an even address, if possible.



Figure 1.26. Time required for executing the interrupt sequence

### Variation of IPL when Interrupt Request is Accepted

If an interrupt request is accepted, the interrupt priority level of the accepted interrupt is set in the IPL. If an interrupt request, that does not have an interrupt priority level, is accepted, one of the values shown in Table 1.12 is set in the IPL.

Table 1.12. Relationship between interrupts without interrupt priority levels and IPL

| Interrupt sources without priority levels | Value set in the IPL |
|-------------------------------------------|----------------------|
| Watchdog timer                            | 7                    |
| Reset                                     | 0                    |
| Other                                     | Not changed          |

### **Saving Registers**

In the interrupt sequence, only the contents of the flag register (FLG) and that of the program counter (PC) are saved in the stack area.

First, the processor saves the 4 high-order bits of the program counter, and 4 high-order bits and 8 low-order bits of the FLG register, 16 bits in total, in the stack area, then saves 16 low-order bits of the program counter. Figure 1.27 shows the state of the stack as it was before the acceptance of the interrupt request, and the state the stack after the acceptance of the interrupt request.

Save other necessary registers at the beginning of the interrupt routine using software. Using the PUSHM instruction alone can save all the registers except the stack pointer (SP).



Figure 1.27. State of stack before and after acceptance of interrupt request



The operation of saving registers carried out in the interrupt sequence is dependent on whether the content of the stack pointer (Note), at the time of acceptance of an interrupt request, is even or odd. If the content of the stack pointer (Note) is even, the content of the flag register (FLG) and the content of the program counter (PC) are saved, 16 bits at a time. If odd, their contents are saved in two steps, 8 bits at a time. Figure 1.28 shows the operation of the saving registers.

Note: Stack pointer indicated by U flag.



Figure 1.28. Operation of saving registers



### **Returning from an Interrupt Routine**

Executing the REIT instruction at the end of an interrupt routine returns the contents of the flag register (FLG) as it was immediately before the start of interrupt sequence and the contents of the program counter (PC), both of which have been saved in the stack area. Then control returns to the program that was being executed before the acceptance of the interrupt request, so that the suspended process resumes.

Return the other registers saved by software within the interrupt routine using the POPM or similar instruction before executing the REIT instruction.

### **Interrupt Priority**

If there are two or more interrupt requests occurring at a point in time within a single sampling (checking whether interrupt requests are made), the interrupt assigned a higher priority is accepted.

Assign an arbitrary priority to maskable interrupts (peripheral I/O interrupts) using the interrupt priority level select bit. If the same interrupt priority level is assigned, however, the interrupt assigned a higher hardware priority is accepted.

Priorities of the special interrupts, such as Reset (dealt with as an interrupt assigned the highest priority), watchdog timer interrupt, etc. are regulated by hardware.

Figure 1.29 shows the priorities of hardware interrupts.

Software interrupts are not affected by the interrupt priority. If an instruction is executed, control branches invariably to the interrupt routine.

# **Interrupt Priority Level Judge Circuit**

This circuit selects the interrupt with the highest priority level when two or more interrupts are generated simultaneously.

Figure 1.30 shows the interrupt resolution circuit.

Reset > DBC > Watchdog timer > Peripheral I/O > Single step > Address match

Figure 1.29. Hardware interrupts priorities



Figure 1.30. Interrupt resolution circuit

### **Key Input Interrupt**

If the direction register of any of P0o to P07 is set for input and a falling edge is input to that port, a key input interrupt is generated. A key input interrupt can also be used as a key-on wakeup function for cancelling the wait mode or stop mode. Figure 1.31 shows the block diagram of the key input interrupt. Note that if an "L" level is input to any pin that has not been disabled for input, inputs to the other pins are not detected as an interrupt.



Figure 1.31. Block diagram of key input interrupt

### **Address Match Interrupt**

An address match interrupt is generated when the address match interrupt address register contents match the program counter value. Two address match interrupts can be set, each of which can be enabled and disabled by an address match interrupt enable bit. Address match interrupts are not affected by the interrupt enable flag (I flag) and processor interrupt priority level (IPL).

Figure 1.32 shows the address match interrupt-related registers.



Figure 1.32. Address match interrupt-related registers



# **Precautions for Interrupts**

### (1) Reading address 0000016

• When maskable interrupt is occurred, CPU read the interrupt information (the interrupt number and interrupt request level) in the interrupt sequence.

The interrupt request bit of the certain interrupt written in address 0000016 will then be set to "0".

Reading address 0000016 by software sets enabled highest priority interrupt source request bit to "0".

Though the interrupt is generated, the interrupt routine may not be executed.

Do not read address 0000016 by software.

# (2) Setting the stack pointer

The value of the stack pointer immediately after reset is initialized to 000016. Accepting an interrupt
before setting a value in the stack pointer may become a factor of runaway. Be sure to set a value in the
stack pointer before accepting an interrupt. Concerning the first instruction immediately after reset,
generating any interrupts is prohibited.

### (3) External interrupt

- Either an "L" level or an "H" level of at least 250 ns width is necessary for the signal input to pins INTO and INT1 regardless of the CPU operation clock.
- When changing a polarity of pins INTO and INT1, the interrupt request bit may become "1". Clear the
  interrupt request bit after changing the polarity. Figure 1.33 shows the switching condition of INT interrupt request.



Figure 1.33. Switching condition of INT interrupt request

### (4) Changing interrupt control register

See "Changing Interrupt Control Register".

### **Watchdog Timer**

The watchdog timer has the function of detecting when the program is out of control. The watchdog timer is a 15-bit counter which down-counts the clock derived by dividing the BCLK using the prescaler. A watchdog timer interrupt is generated when an underflow occurs in the watchdog timer. When XIN is selected for the BCLK, bit 7 of the watchdog timer control register (address 000F16) selects the prescaler division ratio (by 16 or by 128). When XCIN is selected as the BCLK, the prescaler is set for division by 2 regardless of bit 7 of the watchdog timer control register (address 000F16).

When XIN is selected in BCLK

For example, when BCLK is 10MHz and the prescaler division ratio is set to 16, the watchdog timer cycle is approximately 52.4 ms.

The watchdog timer is initialized by writing to the watchdog timer start register (address 000E16) and when a watchdog timer interrupt request is generated. The prescaler is initialized only when the microcomputer is reset. After a reset is cancelled, the watchdog timer and prescaler are both stopped. The count is started by writing to the watchdog timer start register (address 000E16).

Figure 1.34 shows the block diagram of the watchdog timer. Figure 1.35 shows the watchdog timer-related registers.



Figure 1.34. Block diagram of watchdog timer



Figure 1.35. Watchdog timer control and start registers

#### **Timer**

There are six 16-bit timers. These timers can be classified by function into timer A (one), timers B (two) and timers X (three). All these timers function independently. Figure 1.36 show the block diagram of timers.



Figure 1.36. Timer block diagram

#### Timer A

Figure 1.37 shows the block diagram of timer A. Figures 1.38 to 1.40 show the timer A-related registers. Use the timer A0 mode register bits 0 and 1 to choose the desired mode.

Timer A has the four operation modes listed as follows:

- Timer mode: The timer counts an internal count source.
- Event counter mode: The timer counts pulses from an external source or a timer over flow.
- One-shot timer mode: The timer stops counting when the count reaches "000016".
- Pulse width modulation (PWM) mode: The timer outputs pulses of a given width.



Figure 1.37. Block diagram of timer A



Figure 1.38. Timer A-related registers (1)



Figure 1.39. Timer A-related registers (2)



Figure 1.40. Timer A-related registers (3)



### (1) Timer mode

In this mode, the timer counts an internally generated count source. (See Table 1.13.) Figure 1.41 shows the timer A0 mode register in timer mode.

Table 1.13. Specifications of timer mode

| Item                                | Specification                                                                                   |  |
|-------------------------------------|-------------------------------------------------------------------------------------------------|--|
| Count source                        | f1, f8, f32, fc32                                                                               |  |
| Count operation                     | Down count                                                                                      |  |
|                                     | When the timer underflows, it reloads the reload register contents before                       |  |
|                                     | continuing counting                                                                             |  |
| Divide ratio                        | 1/(n+1) n : Set value                                                                           |  |
| Count start condition               | Count start flag is set (= 1)                                                                   |  |
| Count stop condition                | Count start flag is reset (= 0)                                                                 |  |
| Interrupt request generation timing | When the timer underflows                                                                       |  |
| TA0IN pin function                  | Programmable I/O port or gate input                                                             |  |
| TA0OUT pin function                 | Programmable I/O port or pulse output                                                           |  |
| Read from timer                     | Count value can be read out by reading timer A0 register                                        |  |
| Write to timer                      | When counting stopped                                                                           |  |
|                                     | When a value is written to timer A0 register, it is written to both reload register and counter |  |
|                                     | When counting in progress                                                                       |  |
|                                     | When a value is written to timer A0 register, it is written to only reload register             |  |
|                                     | (Transferred to counter at next reload time)                                                    |  |
| Select function                     | Gate function                                                                                   |  |
|                                     | Counting can be started and stopped by the TA0IN pin's input signal                             |  |
|                                     | Pulse output function                                                                           |  |
|                                     | Each time the timer underflows, the TA0out pin's polarity is reversed                           |  |



Figure 1.41. Timer A0 mode register in timer mode



### (2) Event counter mode

In this mode, the timer counts an external signal or an internal timer's overflow. Timer A0 can count a single-phase and a two-phase external signal. Table 1.14 lists timer specifications when counting a single-phase external signal. Figure 1.42 shows the timer A0 mode register in event counter mode. Table 1.15 lists timer specifications when counting a two-phase external signal. Figure 1.43 shows the timer A0 mode register in event counter mode.

Table 1.14. Timer specifications in event counter mode (when not processing two-phase pulse signal)

| Item                                | Specification                                                                                   |  |  |
|-------------------------------------|-------------------------------------------------------------------------------------------------|--|--|
| Count source                        | External signals input to TA0IN pin (effective edge can be selected by software)                |  |  |
|                                     | TB1 overflow, TX0 overflow, TX2 overflow                                                        |  |  |
| Count operation                     | Up count or down count can be selected by external signal or software                           |  |  |
|                                     | When the timer overflows or underflows, it reloads the reload register con                      |  |  |
|                                     | tents before continuing counting (Note)                                                         |  |  |
| Divide ratio                        | $1/(FFFF_{16} - n + 1)$ for up count                                                            |  |  |
|                                     | 1/ (n + 1) for down count n : Set value                                                         |  |  |
| Count start condition               | Count start flag is set (= 1)                                                                   |  |  |
| Count stop condition                | Count start flag is reset (= 0)                                                                 |  |  |
| Interrupt request generation timing | The timer overflows or underflows                                                               |  |  |
| TA0IN pin function                  | Programmable I/O port or count source input                                                     |  |  |
| TA0o∪⊤ pin function                 | Programmable I/O port, pulse output, or up/down count select input                              |  |  |
| Read from timer                     | Count value can be read out by reading timer A0 register                                        |  |  |
| Write to timer                      | When counting stopped                                                                           |  |  |
|                                     | When a value is written to timer A0 register, it is written to both reload register and counter |  |  |
|                                     | When counting in progress                                                                       |  |  |
|                                     | When a value is written to timer A0 register, it is written to only reload register             |  |  |
|                                     | (Transferred to counter at next reload time)                                                    |  |  |
| Select function                     | Free-run count function                                                                         |  |  |
|                                     | Even when the timer overflows or underflows, the reload register content is not reloaded to it  |  |  |
|                                     | Pulse output function                                                                           |  |  |
|                                     | Each time the timer overflows or underflows, the TA0out pin's polarity is reversed              |  |  |

Note: This does not apply when the free-run function is selected.



Figure 1.42. Timer A0 mode register in event counter mode



Table 1.15. Timer specifications in event counter mode (when processing two-phase pulse signal)

| Item                                | Specification                                                                     |  |  |
|-------------------------------------|-----------------------------------------------------------------------------------|--|--|
| Count source                        | Two-phase pulse signals input to TA0IN or TA0OUT pin                              |  |  |
| Count operation                     | Up count or down count can be selected by two-phase pulse signal                  |  |  |
|                                     | When the timer overflows or underflows, the reload register content is            |  |  |
|                                     | reloaded and the timer starts over again (Note)                                   |  |  |
| Divide ratio                        | • 1/ (FFFF <sub>16</sub> - n + 1) for up count                                    |  |  |
|                                     | • 1/ (n + 1) for down count n : Set value                                         |  |  |
| Count start condition               | Count start flag is set (= 1)                                                     |  |  |
| Count stop condition                | Count start flag is reset (= 0)                                                   |  |  |
| Interrupt request generation timing | Timer overflows or underflows                                                     |  |  |
| TA0IN pin function                  | Two-phase pulse input                                                             |  |  |
| TA0out pin function                 | Two-phase pulse input                                                             |  |  |
| Read from timer                     | Count value can be read out by reading timer A0 register                          |  |  |
| Write to timer                      | When counting stopped                                                             |  |  |
|                                     | When a value is written to timer A0 register, it is written to both reload regis- |  |  |
|                                     | ter and counter                                                                   |  |  |
|                                     | When counting in progress                                                         |  |  |
|                                     | When a value is written to timer A0 register, it is written to only reload regis- |  |  |
|                                     | ter. (Transferred to counter at next reload time.)                                |  |  |
| Select function                     | Normal processing operation                                                       |  |  |
| Colour fariotion                    | The timer counts up rising edges or counts down falling edges on the TA0IN        |  |  |
|                                     | pin when input signal on the TA0out pin is "H"                                    |  |  |
|                                     |                                                                                   |  |  |
|                                     |                                                                                   |  |  |
|                                     | TA0out _ L_ L_ L_                                                                 |  |  |
|                                     |                                                                                   |  |  |
|                                     | TAOIN LT L_T V V                                                                  |  |  |
|                                     | Up Up Up Down Down Down count count count count count count count                 |  |  |
|                                     | Count Count Count Count Count                                                     |  |  |
|                                     | a Multiply by 4 processing operation                                              |  |  |
|                                     | • Multiply-by-4 processing operation                                              |  |  |
|                                     | If the phase relationship is such that the TA0IN pin goes "H" when the input      |  |  |
|                                     | signal on the TA00UT pin is "H", the timer counts up rising and falling edges     |  |  |
|                                     | on the TA0out and TA0in pins. If the phase relationship is such that the          |  |  |
|                                     | TA0IN pin goes "L" when the input signal on the TA0out pin is "H", the timer      |  |  |
|                                     | counts down rising and falling edges on the TA0out and TA0in pins.                |  |  |
|                                     | TA0out TA0out                                                                     |  |  |
|                                     |                                                                                   |  |  |
|                                     | Count up all edges Count down all edges                                           |  |  |
|                                     | ' "                                                                               |  |  |
|                                     | TAOIN                                                                             |  |  |
|                                     |                                                                                   |  |  |
|                                     | Count up all edges Count down all edges                                           |  |  |
|                                     | Obant up an ougoo Obant down an ougoo                                             |  |  |

Note: This does not apply when the free-run function is selected.



Figure 1.43. Timer A0 mode register in event counter mode



### (3) One-shot timer mode

In this mode, the timer operates only once. (See Table 1.16.) When a trigger occurs, the timer starts up and continues operating for a given period. Figure 1.44 shows the timer A0 mode register in one-shot timer mode.

Table 1.16. Timer specifications in one-shot timer mode

| Item                                | Specification                                                                          |
|-------------------------------------|----------------------------------------------------------------------------------------|
| Count source                        | f1, f8, f32, fC32                                                                      |
| Count operation                     | The timer counts down                                                                  |
|                                     | When the count reaches 000016, the timer stops counting after reloading a new count    |
|                                     | If a trigger occurs when counting, the timer reloads a new count and restarts counting |
| Divide ratio                        | 1/n n : Set value                                                                      |
| Count start condition               | An external trigger is input                                                           |
|                                     | The timer overflows                                                                    |
|                                     | • The one-shot start flag is set (= 1)                                                 |
| Count stop condition                | A new count is reloaded after the count has reached 0000 <sub>16</sub>                 |
|                                     | • The count start flag is reset (= 0)                                                  |
| Interrupt request generation timing | The count reaches 0000 <sub>16</sub>                                                   |
| TA0IN pin function                  | Programmable I/O port or trigger input                                                 |
| TA0out pin function                 | Programmable I/O port or pulse output                                                  |
| Read from timer                     | When timer A0 register is read, it indicates an indeterminate value                    |
| Write to timer                      | When counting stopped                                                                  |
|                                     | When a value is written to timer A0 register, it is written to both reload             |
|                                     | register and counter                                                                   |
|                                     | When counting in progress                                                              |
|                                     | When a value is written to timer A0 register, it is written to only reload register    |
|                                     | (Transferred to counter at next reload time)                                           |



Figure 1.44. Timer A0 mode register in one-shot timer mode



### (4) Pulse width modulation (PWM) mode

In this mode, the timer outputs pulses of a given width in succession. (See Table 1.17.) In this mode, the counter functions as either a 16-bit pulse width modulator or an 8-bit pulse width modulator. Figure 1.45 shows the timer A0 mode register in pulse width modulation mode. Figure 1.46 shows the example of how a 16-bit pulse width modulator operates. Figure 1.47 shows the example of how an 8-bit pulse width modulator operates.

Table 1.17. Timer specifications in pulse width modulation mode

| Item                                         |             | Specification                                                                             |
|----------------------------------------------|-------------|-------------------------------------------------------------------------------------------|
| Count source                                 |             | f1, f8, f32, fc32                                                                         |
| Count operation                              |             | • The timer counts down (operating as an 8-bit or a 16-bit pulse width modulator)         |
|                                              |             | • The timer reloads a new count at a rising edge of PWM pulse and continues counting      |
|                                              |             | The timer is not affected by a trigger that occurs when counting                          |
| 16-bit PWM                                   |             | High level width    n / fi    n : Set value                                               |
|                                              |             | • Cycle time (2 <sup>16</sup> -1) / fi fixed                                              |
| 8-bit PWM                                    |             | • High level width n ×(m+1) / fi n : values set to timer A0 register's high-order address |
|                                              |             | • Cycle time (28-1) × (m+1) / fi m: values set to timer A0 register's low-order address   |
| Count start condition                        |             | External trigger is input                                                                 |
|                                              |             | The timer overflows                                                                       |
|                                              |             | • The count start flag is set (= 1)                                                       |
| Count stop condition                         |             | • The count start flag is reset (= 0)                                                     |
| Interrupt<br>request<br>generation<br>timing | 8 bits PWM  | • Set value of "H" level width is except FF16, 0016: PWM pulse goes "L"                   |
|                                              |             | • Set value of "H" level width is FF16, 0016: Timing that count value goes to 0116        |
|                                              | 16 bits PWM | • Set value of "H" level width is except FFFF16, 000016: PWM pulse goes "L"               |
|                                              |             | • Set value of "H" level width is FFFF16, 000016: Timing that count value goes to 000116  |
| TA0IN pin function                           |             | Programmable I/O port or trigger input                                                    |
| TA0out pin function                          |             | Pulse output                                                                              |
| Read from timer                              |             | When timer A0 register is read, it indicates an indeterminate value                       |
| Write to timer                               |             | • When counting stopped :When a value is written to timer A0 register, it is              |
|                                              |             | written to both reload register and counter                                               |
|                                              |             | • When counting in progress : When a value is written to timer A0 register, it is         |
|                                              |             | written to only reload register (Transferred to counter at next reload time)              |

Note: When set value of "H" level width is 0016 or 000016, pulse outputs "L" level and inversion value, FF16 or FFFF16 is set to timer.



Figure 1.45. Timer A0 mode register in pulse width modulation mode



Figure 1.46. Example of how a 16-bit pulse width modulator operates



Figure 1.47. Example of how an 8-bit pulse width modulator operates



#### Timer B

Figure 1.48 shows the block diagram of timer B. Figures 1.49 and 1.50 show the timer B-related registers. Use the timer Bi mode register (i = 0, 1) bits 0 and 1 to choose the desired mode.

Timer B has three operation modes listed as follows:

• Timer mode : The timer counts an internal count source.

Event counter mode : The timer counts pulses from an external source or a timer overflow.

• Pulse period/pulse width measuring mode : The timer measures an external signal's pulse period or pulse width.



Figure 1.48. Block diagram of timer B



Figure 1.49. Timer B-related registers (1)



Figure 1.50. Timer B-related registers (2)



# (1) Timer mode

In this mode, the timer counts an internally generated count source. (See Table 1.18.) Figure 1.51 shows the timer Bi mode register in timer mode.

Table 1.18. Timer specifications in timer mode

| Item                                | Specification                                                                                   |  |  |
|-------------------------------------|-------------------------------------------------------------------------------------------------|--|--|
| Count source                        | f1, f8, f32, fC32                                                                               |  |  |
| Count operation                     | Counts down                                                                                     |  |  |
|                                     | When the timer underflows, it reloads the reload register contents before                       |  |  |
|                                     | continuing counting                                                                             |  |  |
| Divide ratio                        | 1/(n+1) n : Set value                                                                           |  |  |
| Count start condition               | Count start flag is set (= 1)                                                                   |  |  |
| Count stop condition                | Count start flag is reset (= 0)                                                                 |  |  |
| Interrupt request generation timing | The timer underflows                                                                            |  |  |
| TBilN pin function                  | Programmable I/O port                                                                           |  |  |
| Read from timer                     | Count value is read out by reading timer Bi register                                            |  |  |
| Write to timer                      | When counting stopped                                                                           |  |  |
|                                     | When a value is written to timer Bi register, it is written to both reload register and counter |  |  |
|                                     | When counting in progress                                                                       |  |  |
|                                     | When a value is written to timer Bi register, it is written to only reload register             |  |  |
|                                     | (Transferred to counter at next reload time)                                                    |  |  |



Figure 1.51. Timer Bi mode register in timer mode



### (2) Event counter mode

In this mode, the timer counts an external signal or an internal timer's overflow. (See Table 1.19.) Figure 1.52 shows the timer Bi mode register in event counter mode.

Table 1.19. Timer specifications in event counter mode

| Item                                | Specification                                                                       |  |  |
|-------------------------------------|-------------------------------------------------------------------------------------|--|--|
| Count source                        | • External signals input to TBilN pin                                               |  |  |
|                                     | • Effective edge of count source can be a rising edge, a falling edge, or falling   |  |  |
|                                     | and rising edges as selected by software                                            |  |  |
| Count operation                     | Counts down                                                                         |  |  |
|                                     | • When the timer underflows, it reloads the reload register contents before         |  |  |
|                                     | continuing counting                                                                 |  |  |
| Divide ratio                        | 1/(n+1) n : Set value                                                               |  |  |
| Count start condition               | Count start flag is set (= 1)                                                       |  |  |
| Count stop condition                | Count start flag is reset (= 0)                                                     |  |  |
| Interrupt request generation timing | The timer underflows                                                                |  |  |
| TBilN pin function                  | Count source input                                                                  |  |  |
| Read from timer                     | Count value can be read out by reading timer Bi register                            |  |  |
| Write to timer                      | When counting stopped                                                               |  |  |
|                                     | When a value is written to timer Bi register, it is written to both reload register |  |  |
|                                     | and counter                                                                         |  |  |
|                                     | When counting in progress                                                           |  |  |
|                                     | When a value is written to timer Bi register, it is written to only reload register |  |  |
|                                     | (Transferred to counter at next reload time)                                        |  |  |



Figure 1.52. Timer Bi mode register in event counter mode



# (3) Pulse period/pulse width measurement mode

In this mode, the timer measures the pulse period or pulse width of an external signal. (See Table 1.20.) Figure 1.53 shows the timer Bi mode register in pulse period/pulse width measurement mode. Figure 1.54 shows the operation timing when measuring a pulse period. Figure 1.55 shows the operation timing when measuring a pulse width.

Table 1.20. Timer specifications in pulse period/pulse width measurement mode

| Item                                | Specification                                                              |  |  |
|-------------------------------------|----------------------------------------------------------------------------|--|--|
| Count source                        | f1, f8, f32, fc32                                                          |  |  |
| Count operation                     | • Up count                                                                 |  |  |
|                                     | Counter value "000016" is transferred to reload register at measurement    |  |  |
|                                     | pulse's effective edge and the timer continues counting                    |  |  |
| Count start condition               | Count start flag is set (= 1)                                              |  |  |
| Count stop condition                | Count start flag is reset (= 0)                                            |  |  |
| Interrupt request generation timing | When measurement pulse's effective edge is input (Note 1)                  |  |  |
|                                     | When an overflow occurs. (Simultaneously, the timer Bi overflow flag       |  |  |
|                                     | changes to "1". The timer Bi overflow flag changes to "0" when the count   |  |  |
|                                     | start flag is "1" and a value is written to the timer Bi mode register.)   |  |  |
| TBiin pin function                  | Measurement pulse input                                                    |  |  |
| Read from timer                     | When timer Bi register is read, it indicates the reload register's content |  |  |
|                                     | (measurement result) (Note 2)                                              |  |  |
| Write to timer                      | Cannot be written to                                                       |  |  |

Note 1: An interrupt request is not generated when the first effective edge is input after the timer has started counting. Note 2: The value read out from the timer Bi register is indeterminate until the second effective edge is input after the timer.



Figure 1.53. Timer Bi mode register in pulse period/pulse width measurement mode



Figure 1.54. Operation timing when measuring a pulse period



Figure 1.55. Operation timing when measuring a pulse width



#### Timer X

Figure 1.56 shows the block diagram of timer X. Figures 1.57 to 1.59 show the timer X-related registers. Use the timer Xi mode register bits 0 and 1 to choose the desired mode.

Timer X has the five operation modes listed as follows:

• Timer mode : The timer counts an internal count source.

• Event counter mode : The timer counts pulses from an external source or a timer overflow.

• One-shot timer mode : The timer stops counting when the count reaches "000016".

• Pulse period/pulse width measuring mode : The timer measures an external signal's pulse period or

pulse width.

Pulse width modulation (PWM) mode
 The timer outputs pulses of a given width.



Figure 1.56. Block diagram of timer X



Figure 1.57. Timer X-related registers (1)



Figure 1.58. Timer X-related registers (2)





Figure 1.59. Timer X-related registers (3)



# (1) Timer mode

In this mode, the timer counts an internally generated count source. (See Table 1.21.) Figure 1.60 shows the timer Xi mode register in timer mode.

Table 1.21. Specifications of timer mode

| Item                                | Specification                                                                                   |  |  |
|-------------------------------------|-------------------------------------------------------------------------------------------------|--|--|
| Count source                        | f1, f8, f32, fC32                                                                               |  |  |
| Count operation                     | Down count                                                                                      |  |  |
|                                     | When the timer underflows, it reloads the reload register contents before continuing counting   |  |  |
| Divide ratio                        | 1/(n+1) n : Set value                                                                           |  |  |
| Count start condition               | Count start flag is set (= 1)                                                                   |  |  |
| Count stop condition                | Count start flag is reset (= 0)                                                                 |  |  |
| Interrupt request generation timing | When the timer underflows                                                                       |  |  |
| TXiINOUT pin function               | Programmable I/O port, gate input or pulse output                                               |  |  |
| Read from timer                     | Count value can be read out by reading timer Xi register                                        |  |  |
| Write to timer                      | When counting stopped                                                                           |  |  |
|                                     | When a value is written to timer Xi register, it is written to both reload register and counter |  |  |
|                                     | When counting in progress                                                                       |  |  |
|                                     | When a value is written to timer Xi register, it is written to only reload register             |  |  |
|                                     | (Transferred to counter at next reload time)                                                    |  |  |
| Select function                     | Gate function                                                                                   |  |  |
|                                     | Counting can be started and stopped by the TXiINOUT pin's input signal                          |  |  |
|                                     | Pulse output function                                                                           |  |  |
|                                     | Each time the timer underflows, the TXiINOUT pin's polarity is reversed                         |  |  |



Figure 1.60. Timer Xi mode register in timer mode



# (2) Event counter mode

In this mode, the timer counts an external signal or an internal timer's overflow. (See Table 1.22.) Figure 1.61 shows the timer Xi mode register in event counter mode.

Table 1.22. Timer specifications in event counter mode (when not processing two-phase pulse signal)

| Item                                | Specification                                                                                   |  |  |
|-------------------------------------|-------------------------------------------------------------------------------------------------|--|--|
| Count source                        | External signals input to TXiINOUT pin (effective edge can be selected by software).            |  |  |
|                                     | TB1 overflow, TA0 overflow, TXi overflow                                                        |  |  |
| Count operation                     | Down count                                                                                      |  |  |
|                                     | When the timer underflows, it reloads the reload register contents before                       |  |  |
|                                     | continuing counting (Note)                                                                      |  |  |
| Divide ratio                        | 1/ (n + 1) n : Set value                                                                        |  |  |
| Count start condition               | Count start flag is set (= 1)                                                                   |  |  |
| Count stop condition                | Count start flag is reset (= 0)                                                                 |  |  |
| Interrupt request generation timing | The timer underflows                                                                            |  |  |
| TXiINOUT pin function               | Programmable I/O port, count source input or pulse output                                       |  |  |
| Read from timer                     | Count value can be read out by reading timer Xi register                                        |  |  |
| Write to timer                      | When counting stopped                                                                           |  |  |
|                                     | When a value is written to timer Xi register, it is written to both reload register and counter |  |  |
|                                     | When counting in progress                                                                       |  |  |
|                                     | When a value is written to timer Xi register, it is written to only reload register             |  |  |
|                                     | (Transferred to counter at next reload time)                                                    |  |  |
| Select function                     | Free-run count function                                                                         |  |  |
|                                     | Even when the timer underflows, the reload register content is not reloaded to it               |  |  |
|                                     | Pulse output function                                                                           |  |  |
|                                     | Each time the timer underflows, the TXiINOUT pin's polarity is reversed                         |  |  |

Note: This does not apply when the free-run function is selected.



Figure 1.61. Timer Xi mode register in event counter mode



# (3) One-shot timer mode

In this mode, the timer operates only once. (See Table 1.23.) When a trigger occurs, the timer starts up and continues operating for a given period. Figure 1.62 shows the timer Xi mode register in one-shot timer mode.

Table 1.23. Timer specifications in one-shot timer mode

| Item                                | Specification                                                                          |  |  |
|-------------------------------------|----------------------------------------------------------------------------------------|--|--|
| Count source                        | f1, f8, f32, fC32                                                                      |  |  |
| Count operation                     | The timer counts down                                                                  |  |  |
|                                     | When the count reaches 000016, the timer stops counting after reloading a new count    |  |  |
|                                     | If a trigger occurs when counting, the timer reloads a new count and restarts counting |  |  |
| Divide ratio                        | 1/n n : Set value                                                                      |  |  |
| Count start condition               | An external trigger is input                                                           |  |  |
|                                     | The timer overflows                                                                    |  |  |
|                                     | • The one-shot start flag is set (= 1)                                                 |  |  |
| Count stop condition                | A new count is reloaded after the count has reached 000016                             |  |  |
|                                     | • The count start flag is reset (= 0)                                                  |  |  |
| Interrupt request generation timing | The count reaches 000016                                                               |  |  |
| TXiINOUT pin function               | Programmable I/O port, trigger input or pulse output                                   |  |  |
| Read from timer                     | When timer Xi register is read, it indicates an indeterminate value                    |  |  |
| Write to timer                      | When counting stopped                                                                  |  |  |
|                                     | When a value is written to timer Xi register, it is written to both reload             |  |  |
|                                     | register and counter                                                                   |  |  |
|                                     | When counting in progress                                                              |  |  |
|                                     | When a value is written to timer Xi register, it is written to only reload register    |  |  |
|                                     | (Transferred to counter at next reload time)                                           |  |  |



Figure 1.62. Timer Xi mode register in one-shot timer mode



# (4) Pulse period/pulse width measurement mode

In this mode, the timer measures the pulse period or pulse width of an external signal. (See Table 1.24.) Figure 1.63 shows the timer Xi mode register in pulse period/pulse width measurement mode. Figure 1.64 shows the operation timing when measuring a pulse period. Figure 1.65 shows the operation timing when measuring a pulse width.

Table 1.24. Timer specifications in pulse period/pulse width measurement mode

| Item                                | Specification                                                              |  |  |
|-------------------------------------|----------------------------------------------------------------------------|--|--|
| Count source                        | f1, f8, f32, fc32                                                          |  |  |
| Count operation                     | • Up count                                                                 |  |  |
|                                     | Counter value "000016" is transferred to reload register at measurement    |  |  |
|                                     | pulse's effective edge and the timer continues counting                    |  |  |
| Count start condition               | Count start flag is set (= 1)                                              |  |  |
| Count stop condition                | Count start flag is reset (= 0)                                            |  |  |
| Interrupt request generation timing | When measurement pulse's effective edge is input (Note 1)                  |  |  |
|                                     | When an overflow occurs. (Simultaneously, the timer Xi overflow flag       |  |  |
|                                     | changes to "1". The timer Xi overflow flag changes to "0" when the count   |  |  |
|                                     | start flag is "1" and a value is written to the timer Xi mode register.)   |  |  |
| TXiINOUT pin function               | Measurement pulse input                                                    |  |  |
| Read from timer                     | When timer Xi register is read, it indicates the reload register's content |  |  |
|                                     | (measurement result) (Note 2)                                              |  |  |
| Write to timer                      | Cannot be written to                                                       |  |  |

Note 1: An interrupt request is not generated when the first effective edge is input after the timer has started counting. Note 2: The value read out from the timer Xi register is indeterminate until the second effective edge is input after the timer.



Figure 1.63. Timer Xi mode register in pulse period/pulse width measurement mode



Figure 1.64. Operation timing when measuring a pulse period



Figure 1.65. Operation timing when measuring a pulse width



# (5) Pulse width modulation (PWM) mode

In this mode, the timer outputs pulses of a given width in succession. (See Table 1.25.) In this mode, the counter functions as either a 16-bit pulse width modulator or an 8-bit pulse width modulator. Figure 1.66 shows the timer Xi mode register in pulse width modulation mode. Figure 1.67 shows the example of how a 16-bit pulse width modulator operates. Figure 1.68 shows the example of how an 8-bit pulse width modulator operates.

Table 1.25. Timer specifications in pulse width modulation mode

| Ite             | em          | Specification                                                                                      |  |
|-----------------|-------------|----------------------------------------------------------------------------------------------------|--|
| Count source    |             | f1, f8, f32, fC32                                                                                  |  |
| Count operation |             | Down counts (operating as an 8-bit or a 16-bit pulse width modulator)                              |  |
|                 |             | The timer reloads a new count at a rising edge of PWM pulse and continues counting                 |  |
|                 |             | The timer is not affected by a trigger that occurs when counting                                   |  |
| 16-bit PWM      |             | "H" level width n / fi     n : Set value                                                           |  |
|                 |             | Cycle time (2 <sup>16</sup> -1) / fi fixed                                                         |  |
| 8-bit PWM       |             | • "H" level width n×(m+1)/ fi n:values set to timer Xi register's high-order address               |  |
|                 |             | • Cycle time (2 <sup>8</sup> -1)×(m+1) / fi m: values set to timer Xi register's low-order address |  |
| Count start     | condition   | The timer overflows                                                                                |  |
|                 |             | The count start flag is set (= 1)                                                                  |  |
| Count stop of   | condition   | The count start flag is reset (= 0)                                                                |  |
| Interrupt       | 8 bits PWM  | Set value of "H" level width is except FF16, 0016: PWM pulse goes "L"                              |  |
| request         |             | Set value of "H" level width is FF16, 0016: Timing that count value goes to 0116                   |  |
|                 | 16 bits PWM | Set value of "H" level width is except FFFF16, 000016: PWM pulse goes "L"                          |  |
| timing          |             | Set value of "H" level width is FFFF16, 000016: Timing that count value goes to 000116             |  |
| TXiINOUT pir    | n function  | Pulse output                                                                                       |  |
| Read from t     | imer        | When timer Xi register is read, it indicates an indeterminate value                                |  |
| Write to timer  |             | When counting stopped                                                                              |  |
|                 |             | When a value is written to timer Xi register, it is written to both reload register and counted    |  |
|                 |             | When counting in progress                                                                          |  |
|                 |             | When a value is written to timer Xi register, it is written to only reload register                |  |
|                 |             | (Transferred to counter at next reload time)                                                       |  |

Note: When set value of "H" level width is 0016 or 000016, pulse outputs "L" level and inversion value, FF16 or FFFF16 is set to timer.



Figure 1.66. Timer Xi mode register in pulse width modulation mode



Figure 1.67. Example of how a 16-bit pulse width modulator operates



Figure 1.68. Example of how an 8-bit pulse width modulator operates

#### Serial I/O

Serial I/O is configured as two channels: UART0 and UART1.

UART0 and UART1 each have an exclusive timer to generate a transfer clock, so they operate independently of each other.

Figure 1.69 shows the block diagram of UART0 and UART1. Figure 1.70 shows the block diagram of the transmit/receive unit.

UART0 has two operation modes: a clock synchronous serial I/O mode and a clock asynchronous serial I/O mode (UART mode). The contents of the serial I/O mode select bits (bits 0 to 2 at addresses 03A016 and 03A816) determine whether UART0 is used as a clock synchronous serial I/O or as a UART.

UART1 is used as a UART only.

Figures 1.71 through 1.73 show the registers related to UARTi.



Figure 1.69. Block diagram of UARTi (i = 0, 1)



Figure 1.70. Block diagram of transmit/receive unit



Figure 1.71. Serial I/O-related registers (1)



Figure 1.72. Serial I/O-related registers (2)

#### UARTi transmit/receive control register 1 Symbol Address When reset UiC1(i=0,1) 03A516,03AD16 0216 Function (Note 1) Bit Function Bit name (During clock synchronous R W symbol (During UART mode) serial I/O mode) TE Transmit enable bit 0: Transmission disabled 0: Transmission disabled 00 1: Transmission enabled 1: Transmission enabled ΤI Transmit buffer 0: Data present in 0: Data present in empty flag transmit buffer register transmit buffer register OX 1 : No data present in 1 : No data present in transmit buffer register transmit buffer register 0: Reception disabled RE Receive enable bit 0: Reception disabled 00 (Note 2) 1: Reception enabled 1: Reception enabled RI Receive complete flag 0: No data present in 0 : No data present in receive buffer register receive buffer register O X 1 : Data present in 1: Data present in receive buffer register receive buffer register Nothing is assigned. When write, set "0". When read, the value of these bits is "0".

Note 1: UART1 cannot be used in clock synchronous serial I/O.

Note 2: If you are using clock asynchronous serial I/O mode, you can enable 'receive enable bit' when RxD port input is "H". If RxD port input is "L" and you have enabled 'receive enable bit', then receive operation starts immediately.

#### UART transmit/receive control register 2



Note 1: UART1 cannot be used in clock synchronous serial I/O.

Note 2: When using multiple pins to output the transfer clock, the following requirements must be met:

• UART0 internal/external clock select bit (bit 3 at address 03A016) = "0".

Figure 1.73. Serial I/O-related registers (3)

# (1) Clock synchronous serial I/O mode

The clock synchronous serial I/O mode uses a transfer clock to transmit and receive data. (See Table 1.26.) Figure 1.65 shows the UART0 transmit/receive mode register.

Table 1.26. Specifications of clock synchronous serial I/O mode

| Item                 | Specification                                                                              |  |  |
|----------------------|--------------------------------------------------------------------------------------------|--|--|
| Transfer data format | Transfer data length: 8 bits                                                               |  |  |
| Transfer clock       | • When internal clock is selected (bit 3 at address 03A016 = "0") : fi/ 2(n+1) (Note 1)    |  |  |
|                      | fi = f1, f8, f32, fc                                                                       |  |  |
|                      | • When external clock is selected (bit 3 at address 03A016 = "1") : Input from CLK0 pin    |  |  |
| Transmission start   | To start transmission, the following requirements must be met:                             |  |  |
| condition            | - Transmit enable bit (bit 0 at address 03A516) = "1"                                      |  |  |
|                      | - Transmit buffer empty flag (bit 1 at addresses 03A516) = "0"                             |  |  |
|                      | • Furthermore, if external clock is selected, the following requirements must also be met: |  |  |
|                      | - CLK0 polarity select bit (bit 6 at address 03A416) = "0": CLK0 input level = "H"         |  |  |
|                      | - CLK0 polarity select bit (bit 6 at address 03A416) = "1": CLK0 input level = "L"         |  |  |
| Reception start      | To start reception, the following requirements must be met:                                |  |  |
| conditio             | <ul><li>Receive enable bit (bit 2 at address 03A516) = "1"</li></ul>                       |  |  |
|                      | - Transmit enable bit (bit 0 at address 03A516) = "1"                                      |  |  |
|                      | - Transmit buffer empty flag (bit 1 at address 03A516) = "0"                               |  |  |
|                      | • Furthermore, if external clock is selected, the following requirements must also be met: |  |  |
|                      | - CLK0 polarity select bit (bit 6 at address 03A416) = "0": CLK0 input level = "H"         |  |  |
|                      | - CLK0 polarity select bit (bit 6 at address 03A416) = "1": CLK0 input level = "L"         |  |  |
| Interrupt request    | When transmitting                                                                          |  |  |
| generation timing    | - Transmit interrupt cause select bit (bit 0 at address 03B016) = "0": Interrupts re-      |  |  |
|                      | quested when data transfer from UART0 transfer buffer register to UART0 transmit           |  |  |
|                      | register is completed                                                                      |  |  |
|                      | - Transmit interrupt cause select bit (bit 0 at address 03B016) = "1": Interrupts re-      |  |  |
|                      | quested when data transmission from UART0 transfer register is completed                   |  |  |
|                      | When receiving                                                                             |  |  |
|                      | - Interrupts requested when data transfer from UART0 receive register to UART0             |  |  |
|                      | receive buffer register is completed                                                       |  |  |
| Error detection      | Overrun error (Note 2)                                                                     |  |  |
|                      | This error occurs when the next data is ready before contents of UART0 receive             |  |  |
|                      | buffer register are read out                                                               |  |  |
| Select function      | CLK polarity selection                                                                     |  |  |
|                      | Whether transmit data is output/input at the rising edge or falling edge of the trans-     |  |  |
|                      | fer clock can be selected                                                                  |  |  |
|                      | LSB first/MSB first selection                                                              |  |  |
|                      | Whether transmission/reception begins with bit 0 or bit 7 can be selected                  |  |  |
|                      | Continuous receive mode selection                                                          |  |  |
|                      | Reception is enabled simultaneously by a read from the receive buffer register             |  |  |
|                      | Transfer clock output from multiple pins selection                                         |  |  |
|                      | UART0 transfer clock can be chosen by software to be output from one of the two            |  |  |
|                      | pins set                                                                                   |  |  |

Note 1: "n" denotes the value 0016 to FF16 that is set to the UART bit rate generator.

Note 2: If an overrun error occurs, the UART0 receive buffer will have the next data written in. Note also that the UART0 receive interrupt request bit is not set to "1".



Figure 1.74. UART0 transmit/receive mode register in clock synchronous serial I/O mode

Table 1.27 lists the functions of the input/output pins during clock synchronous serial I/O mode. Note that for a period from when the UARTO operation mode is selected to when transfer starts, the TxDO pin outputs a "H". (If the N-channel open-drain is selected, this pin is in floating state.)

Table 1.27. Input/output pin functions in clock synchronous serial I/O mode

| Pin name      | Function              | Method of selection                                                                                                            |
|---------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------|
| TxD0<br>(P50) | Serial data output    | Port P50 direction register (bit 0 at address 03EB16)= "1" (Outputs dummy data when performing reception only)                 |
| RxD0<br>(P51) | Serial data input     | Port P51 direction register (bit 1 at address 03EB16)= "0" (Can be used as an input port when performing transmission only)    |
| CLK0<br>(P52) | Transfer clock output | Internal/external clock select bit (bit 3 at address 03A016) = "0"                                                             |
|               | Transfer clock input  | Internal/external clock select bit (bit 3 at address 03A016) = "1" Port P52 direction register (bit 2 at address 03EB16) = "0" |





Figure 1.75. Typical transmit/receive timings in clock synchronous serial I/O mode

#### (a) Polarity select function

As shown in Figure 1.76, the CLK polarity select bit (bit 6 at addresses 03A416) allows selection of the polarity of the transfer clock.



Figure 1.76. Polarity of transfer clock

#### (b) LSB first/MSB first select function

As shown in Figure 1.77, when the transfer format select bit (bit 7 at addresses 03A416) = "0", the transfer format is "LSB first"; when the bit = "1", the transfer format is "MSB first".



Figure 1.77. Transfer format

#### (c) Transfer clock output from multiple pins function

This function allows the setting two transfer clock output pins and choosing one of the two to output a clock by using the CLK and CLKS select bit (bits 4 and 5 at address 03B016). (See Figure 1.78.) The multiple pins function is valid only when the internal clock is selected for UART0.



Figure 1.78. The transfer clock output from the multiple pins function usage

#### (d) Continuous receive mode

If the continuous receive mode enable bit (bits 2 and 3 at address 03B016) is set to "1", the unit is placed in continuous receive mode. In this mode, when the receive buffer register is read out, the unit simultaneously goes to a receive enable state without having to set dummy data to the transmit buffer register back again.

# (2) Clock asynchronous serial I/O (UART) mode

The UART mode allows transmitting and receiving data after setting the desired transfer rate and transfer data format. (See Table 1.28.) Figure 1.79 shows the UARTi transmit/receive mode register.

Table 1.28. Specifications of UART Mode

| Item                   | Specification                                                                 |  |
|------------------------|-------------------------------------------------------------------------------|--|
| Transfer data format   | Character bit (transfer data): 7 bits, 8 bits, or 9 bits as selected          |  |
|                        | Start bit: 1 bit                                                              |  |
|                        | Parity bit: Odd, even, or nothing as selected                                 |  |
|                        | Stop bit: 1 bit or 2 bits as selected                                         |  |
| Transfer clock         | • When internal clock is selected (bit 3 at addresses 03A016, 03A816 = "0"):  |  |
|                        | fi/16(n+1) (Note 1) fi = f1, f8, f32, fC                                      |  |
|                        | • When external clock is selected (bit 3 at addresses 03A016="1"):            |  |
|                        | fEXT/16(n+1) (Note 1) (Note 2)                                                |  |
| Transmission start     | To start transmission, the following requirements must be met:                |  |
| condition              | - Transmit enable bit (bit 0 at addresses 03A516, 03AD16) = "1"               |  |
|                        | - Transmit buffer empty flag (bit 1 at addresses 03A516, 03AD16) = "0"        |  |
| Reception start condi- | To start reception, the following requirements must be met:                   |  |
| tion                   | - Receive enable bit (bit 2 at addresses 03A516, 03AD16) = "1"                |  |
|                        | - Start bit detection                                                         |  |
| Interrupt request gen- | When transmitting                                                             |  |
| eration timing         | - Transmit interrupt cause select bits (bits 0,1 at address 03B016) = "0":    |  |
|                        | Interrupts requested when data transfer from UARTi transfer buffer register   |  |
|                        | to UARTi transmit register is completed                                       |  |
|                        | - Transmit interrupt cause select bits (bits 0, 1 at address 03B016) = "1":   |  |
|                        | Interrupts requested when data transmission from UARTi transfer register is   |  |
|                        | completed                                                                     |  |
|                        | When receiving                                                                |  |
|                        | - Interrupts requested when data transfer from UARTi receive register to      |  |
|                        | UARTi receive buffer register is completed                                    |  |
| Error detection        | Overrun error (Note 3)                                                        |  |
|                        | This error occurs when the next data is ready before contents of UARTi        |  |
|                        | receive buffer register are read out                                          |  |
|                        | Framing error                                                                 |  |
|                        | This error occurs when the number of stop bits set is not detected            |  |
|                        | Parity error                                                                  |  |
|                        | This error occurs when if parity is enabled, the number of 1's in parity and  |  |
|                        | character bits does not match the number of 1's set                           |  |
|                        | Error sum flag                                                                |  |
|                        | This flag is set (= 1) when any of the overrun, framing, and parity errors is |  |
|                        | encountered                                                                   |  |
| Select function        | Sleep mode selection                                                          |  |
|                        | This mode is used to transfer data to and from one of multiple slave micro-   |  |
|                        | computers                                                                     |  |

Note 1: 'n' denotes the value 0016 to FF16 that is set to the UART bit rate generator.

Note 2: fEXT is input from the CLK0 pin. Since UART1 does not have this pin, cannot select external clock.

Note 3: If an overrun error occurs, the UARTi receive buffer will have the next data written in. Note also that the UARTi receive interrupt request bit is not set to "1".





Figure 1.79. UARTi transmit/receive mode register in UART mode

Table 1.29 lists the functions of the input/output pins during UART mode. Note that for a period from when the UARTi operation mode is selected to when transfer starts, the TxDi pin outputs a "H". (If the N-channel open-drain is selected, this pin is in floating state.)

Table 1.29. Input/output pin functions in UART mode

| Pin name           | Function                                   | Method of selection                                                                                                                                          |
|--------------------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TxDi<br>(P50, P40) | Serial data output                         | Port P51 and P42 direction register (bit 0 at address 03EB16, bit 0 at address 03EA16)= "1" (Can be used as an input port when performing reception only)    |
| RxDi<br>(P51, P42) | Serial data input                          | Port P51 and P42 direction register (bit 1 at address 03EB16, bit 2 at address 03EA16)= "0" (Can be used as an input port when performing transmission only) |
| CLK0<br>(P52)      | Programmable I/O port Transfer clock input | Internal/external clock select bit (bit 3 at address 03A016) = "0"  Internal/external clock select bit (bit 3 at address 03A016) = "1"                       |



# • Example of transmit timing when transfer data is 8 bits long (parity enabled, one stop bit)



Shown in ( ) are bit symbols.

The above timing applies to the following settings :

- Parity is enabled.
- One stop bit.
- Transmit interrupt cause select bit = "1".

Tc = 16 (n + 1) / fi or 16 (n + 1) / fext

fi : frequency of BRGi count source (f1, f8, f32, fc)

fEXT : frequency of BRGi count source (external clock)

n : value set to BRGi

• Example of transmit timing when transfer data is 9 bits long (parity disabled, two stop bits)



Figure 1.80. Typical transmit timings in UART mode





Figure 1.81. Typical receive timing in UART mode

#### (a) Sleep mode

This mode is used to transfer data between specific microcomputers among multiple microcomputers connected using UARTi. The sleep mode is selected when the sleep select bit (bit 7 at addresses 03A016, 03A816) is set to "1" during reception. In this mode, the unit performs receive operation when the MSB of the received data = "1" and does not perform receive operation when the MSB = "0".

#### **A-D Converter**

The A-D converter consists of one 10-bit successive approximation A-D converter circuit with a capacitive coupling amplifier. Pins P60 to P67, and P50 to P54 also function as the analog signal input pins. The direction registers of these pins for A-D conversion must therefore be set to input. The Vref connect bit (bit 5 at address 03D716) can be used to isolate the resistance ladder of the A-D converter from the reference voltage input pin (VREF) when the A-D converter is not used. Doing so stops any current flowing into the resistance ladder from VREF, reducing the power dissipation. When using the A-D converter, start A-D conversion only after setting bit 5 of 03D716 to connect VREF.

The result of A-D conversion is stored in the A-D registers of the selected pins. When set to 10-bit precision, the low 8 bits are stored in the even addresses and the high 2 bits in the odd addresses. When set to 8-bit precision, the low 8 bits are stored in the even addresses.

Table 1.30 shows the performance of the A-D converter. Figure 1.82 shows the block diagram of the A-D converter, and Figures 1.83 and 1.84 show the A-D converter-related registers.

Table 1.30. Performance of A-D converter

| Item                                | Performance                                                             |
|-------------------------------------|-------------------------------------------------------------------------|
| Method of A-D conversion            | Successive approximation (capacitive coupling amplifier)                |
| Analog input voltage (Note 1)       | 0V to AVcc (Vcc)                                                        |
| Operating clock \$\phiAD\$ (Note 2) | VCC = 5V fAD, divide-by-2 of fAD, divide-by-4 of fAD, fAD=f(XIN)        |
|                                     | VCC = 3V divide-by-2 of fAD, divide-by-4 of fAD, fAD=f(XIN)             |
| Resolution                          | 8-bit or 10-bit (selectable)                                            |
| Absolute precision                  | Vcc = 5V • Without sample and hold function                             |
|                                     | ±3LSB                                                                   |
|                                     | <ul> <li>With sample and hold function (8-bit resolution)</li> </ul>    |
|                                     | ±2LSB                                                                   |
|                                     | <ul> <li>With sample and hold function (10-bit resolution)</li> </ul>   |
|                                     | ±3LSB                                                                   |
|                                     | Vcc = 3V • Without sample and hold function (8-bit resolution)          |
|                                     | ±2LSB                                                                   |
| Operating modes                     | One-shot mode, repeat mode, single sweep mode, repeat sweep mode 0,     |
|                                     | and repeat sweep mode 1                                                 |
| Analog input pins                   | 8 pins (ANo to AN7) + 5 pins (AN50 to AN54)                             |
| A-D conversion start condition      | Software trigger                                                        |
|                                     | A-D conversion starts when the A-D conversion start flag changes to "1" |
| Conversion speed per pin            | Without sample and hold function                                        |
|                                     | 8-bit resolution: 49 φAD cycles, 10-bit resolution: 59 φAD cycles       |
|                                     | With sample and hold function                                           |
|                                     | 8-bit resolution: 28 φAD cycles, 10-bit resolution: 33 φAD cycles       |

Note 1: Does not depend on use of sample and hold function.

Note 2: Without sample and hold function, set the  $\phi AD$  frequency to 250kHz min. With the sample and hold function, set the  $\phi AD$  frequency to 1MHz min.



Figure 1.82. Block diagram of A-D converter



Note 1: If the A-D control register is rewritten during A-D conversion, the conversion result is indeterminate.

Note 2: AN50 to AN54 can be used in the same way as for AN0 to AN4.

#### A-D control register 1 (Note 1)

b4 b3 b2 b1

b6



Note 1: If the A-D control register is rewritten during A-D conversion, the conversion result is indeterminate.

Note 2: AN50 to AN54 can be used in the same way as for AN0 to AN4.

Note 3: If the repeat sweep mode is selected for the port P5 group, the contents of A-D registers 5 to 7 are indeterminate.

Figure 1.83. A-D converter-related registers (1)



Figure 1.84. A-D converter-related registers (2)



### (1) One-shot mode

In one-shot mode, the pin selected using the analog input pin select bit is used for one-shot A-D conversion. (See Table 1.31.) Figure 1.85 shows the A-D control register in one-shot mode.

Table 1.31. One-shot mode specifications

| Item                                | Specification                                                                      |
|-------------------------------------|------------------------------------------------------------------------------------|
| Function                            | The pin selected by the analog input pin select bit is used for one A-D conversion |
| Start condition                     | Writing "1" to A-D conversion start flag                                           |
| Stop condition                      | • End of A-D conversion (A-D conversion start flag changes to "0")                 |
|                                     | Writing "0" to A-D conversion start flag                                           |
| Interrupt request generation timing | End of A-D conversion                                                              |
| Input pin                           | One of ANo to AN7, as selected (Note)                                              |
| Reading of result of A-D converter  | Read A-D register corresponding to selected pin                                    |

Note: AN50 to AN54 can be used in the same way as for AN0 to AN4.



Figure 1.85. A-D conversion register in one-shot mode



#### (2) Repeat mode

In repeat mode, the pin selected using the analog input pin select bit is used for repeated A-D conversion. (See Table 1.32.) Figure 1.86 shows the A-D control register in repeat mode.

Table 1.32. Repeat mode specifications

| Item                                | Specification                                                                           |
|-------------------------------------|-----------------------------------------------------------------------------------------|
| Function                            | The pin selected by the analog input pin select bit is used for repeated A-D conversion |
| Start condition                     | Writing "1" to A-D conversion start flag                                                |
| Stop condition                      | Writing "0" to A-D conversion start flag                                                |
| Interrupt request generation timing | None generated                                                                          |
| Input pin                           | One of ANo to AN7, as selected (Note)                                                   |
| Reading of result of A-D converter  | Read A-D register corresponding to selected pin                                         |



Figure 1.86. A-D conversion register in repeat mode



## (3) Single sweep mode

In single sweep mode, the pins selected using the A-D sweep pin select bit are used for one-by-one A-D conversion. (See Table 1.33.) Figure 1.87 shows the A-D control register in single sweep mode.

Table 1.33. Single sweep mode specifications

| Item                                | Specification                                                                                |
|-------------------------------------|----------------------------------------------------------------------------------------------|
| Function                            | The pins selected by the A-D sweep pin select bit are used for one-by-one A-D conversion     |
| Start condition                     | Writing "1" to A-D converter start flag                                                      |
| Stop condition                      | • End of A-D conversion (A-D conversion start flag changes to "0".)                          |
|                                     | Writing "0" to A-D conversion start flag                                                     |
| Interrupt request generation timing | End of A-D conversion                                                                        |
| Input pin                           | ANo and AN1 (2 pins), ANo to AN3 (4 pins), ANo to AN5 (6 pins), or ANo to AN7 (8 pins)(Note) |
| Reading of result of A-D converter  | Read A-D register corresponding to selected pin                                              |



Figure 1.87. A-D conversion register in single sweep mode



#### (4) Repeat sweep mode 0

In repeat sweep mode 0, the pins selected using the A-D sweep pin select bit are used for repeat sweep A-D conversion. (See Table 1.34.) Figure 1.88 shows the A-D control register in repeat sweep mode 0.

Table 1.34. Repeat sweep mode 0 specifications

| Item                                | Specification                                                                                |
|-------------------------------------|----------------------------------------------------------------------------------------------|
| Function                            | The pins selected by the A-D sweep pin select bit are used for repeat sweep A-D conversion   |
| Start condition                     | Writing "1" to A-D conversion start flag                                                     |
| Stop condition                      | Writing "0" to A-D conversion start flag                                                     |
| Interrupt request generation timing | None generated                                                                               |
| Input pin                           | ANo and AN1 (2 pins), ANo to AN3 (4 pins), ANo to AN5 (6 pins), or ANo to AN7 (8 pins)(Note) |
| Reading of result of A-D converter  | Read A-D register corresponding to selected pin (at any time)                                |



Figure 1.88. A-D conversion register in repeat sweep mode 0



## (5) Repeat sweep mode 1

In repeat sweep mode 1, all pins are used for A-D conversion with emphasis on the pin or pins selected using the A-D sweep pin select bit. (See Table 1.35.) Figure 1.89 shows the A-D control register in repeat sweep mode

Table 1.35. Repeat sweep mode 1 specifications

| Item                                | Specification                                                                                                             |  |  |  |  |
|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Function                            | All pins perform repeat sweep A-D conversion, with emphasis on the pin or                                                 |  |  |  |  |
|                                     | pins selected by the A-D sweep pin select bit                                                                             |  |  |  |  |
|                                     | Example : ANo selected ANo $\rightarrow$ AN1 $\rightarrow$ AN0 $\rightarrow$ AN2 $\rightarrow$ AN0 $\rightarrow$ AN3, etc |  |  |  |  |
| Start condition                     | Writing "1" to A-D conversion start flag                                                                                  |  |  |  |  |
| Stop condition                      | Writing "0" to A-D conversion start flag                                                                                  |  |  |  |  |
| Interrupt request generation timing | None generated                                                                                                            |  |  |  |  |
| Input pin                           | ANo (1 pin), ANo and AN1 (2 pins), ANo to AN2 (3 pins), ANo to AN3 (4 pins) (Note)                                        |  |  |  |  |
| Reading of result of A-D converter  | Read A-D register corresponding to selected pin (at any time)                                                             |  |  |  |  |



Figure 1.89. A-D conversion register in repeat sweep mode 1

# Sample and hold

Sample and hold is selected by setting bit 0 of the A-D control register 2 (address 03D416) to "1". When sample and hold is selected, the rate of conversion of each pin increases. As a result, a 28  $\phi$ AD cycle is achieved with 8-bit resolution and 33  $\phi$ AD with 10-bit resolution. Sample and hold can be selected in all modes. However, in all modes, be sure to specify before starting A-D conversion whether sample and hold is to be used.

## Programmable I/O Ports

There are 43 programmable I/O ports: P0 to P7. Each port can be set independently for input or output using the direction register. A pull-up resistance for each block of 4 ports can be set. The port P1 allows the drive capacity of its N-channel output transistor to be set as necessary.

Figures 1.90 to 1.92 show the programmable I/O ports.

Each pin functions as a programmable I/O port and as the I/O for the built-in peripheral devices.

To use the pins as the inputs for the built-in peripheral devices, set the direction register of each pin to input mode. When the pins are used as the outputs for the built-in peripheral devices, they function as outputs regardless of the contents of the direction registers. See the descriptions of the respective functions for how to set up the built-in peripheral devices.

# (1) Direction registers

Figure 1.93 shows the direction registers.

These registers are used to choose the direction of the programmable I/O ports. Each bit in these registers corresponds one for one to each I/O pin.

## (2) Port registers

Figure 1.94 shows the port registers.

These registers are used to write and read data for input and output to and from an external device. A port register consists of a port latch to hold output data and a circuit to read the status of a pin. Each bit in port registers corresponds one for one to each I/O pin.

#### (3) Pull-up control registers

Figure 1.95 shows the pull-up control registers.

The pull-up control register can be set to apply a pull-up resistance to each block of 4 ports. When ports are set to have a pull-up resistance, the pull-up resistance is connected only when the direction register is set for input.

#### (4) Port P1 drive capacity control register

Figure 1.95 shows a structure of the port P1 drive capacity control register.

This register is used to control the drive capacity of the port P1's N-channel output transistor. Each bit in this register corresponds one for one to the port pins.



Figure 1.90. Programmable I/O ports (1)



Figure 1.91. Programmable I/O ports (2)



Figure 1.92. Programmable I/O ports (3)



Figure 1.93. Direction register



Figure 1.94. Port register



Figure 1.95. Pull-up control register

# **Example connection of unused pins**

Table 1.36. Example connection of unused pins

| Pin name               | Connection                                                                                                                   |
|------------------------|------------------------------------------------------------------------------------------------------------------------------|
| Ports P0, P1, P3 to P7 | After setting for input mode, connect every pin to Vss (pull-down); or after setting for output mode, leave these pins open. |
| XOUT (Note)            | Open                                                                                                                         |
| AVcc                   | Connect to Vcc                                                                                                               |
| AVSS, VREF             | Connect to Vss                                                                                                               |

Note: With external clock input to XIN pin.

# **Usage Precaution**

## Timer A (timer mode)

(1) Reading the timer A0 register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the timer A0 register with the reload timing gets "FFF16". Reading the timer A0 register after setting a value in the timer A0 register with a count halted but before the counter starts counting gets a proper value.

# Timer A (event counter mode)

- (1) Reading the timer A0 register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the timer A0 register with the reload timing gets "FFFF16" by underflow or "000016" by overflow. Reading the timer A0 register after setting a value in the timer A0 register with a count halted but before the counter starts counting gets a proper value.
- (2) When stop counting in free run type, set timer again.

## Timer A (one-shot timer mode)

- (1) Setting the count start flag to "0" while a count is in progress causes as follows:
  - The counter stops counting and a content of reload register is reloaded.
  - The TA0out pin outputs "L" level.
  - The interrupt request generated and the timer A0 interrupt request bit goes to "1".
- (2) The timer A0 interrupt request bit goes to "1" if the timer's operation mode is set using any of the following procedures:
  - Selecting one-shot timer mode after reset.
  - Changing operation mode from timer mode to one-shot timer mode.
  - Changing operation mode from event counter mode to one-shot timer mode.

Therefore, to use timer A0 interrupt (interrupt request bit), set timer A0 interrupt request bit to "0" after the above listed changes have been made.

## Timer A (pulse width modulation mode)

- (1) The timer A0 interrupt request bit becomes "1" if setting operation mode of the timer in compliance with any of the following procedures:
  - Selecting PWM mode after reset.
  - Changing operation mode from timer mode to PWM mode.
  - Changing operation mode from event counter mode to PWM mode.

Therefore, to use timer A0 interrupt (interrupt request bit), set timer A0 interrupt request bit to "0" after the above listed changes have been made.

(2) Setting the count start flag to "0" while PWM pulses are being output causes the counter to stop counting. If the TA0out pin is outputting an "H" level in this instance, the output level goes to "L", and the timer A0 interrupt request bit goes to "1". If the TA0out pin is outputting an "L" level in this instance, the level does not change, and the timer A0 interrupt request bit does not becomes "1".

## Timer B (timer mode, event counter mode)

(1) Reading the timer Bi register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the timer Bi register with the reload timing gets "FFFF16". Reading the timer Bi register after setting a value in the timer Bi register with a count halted but before the counter starts counting gets a proper value.

## Timer B (pulse period/pulse width measurement mode)

- (1) If changing the measurement mode select bit is set after a count is started, the timer Bi interrupt request bit goes to "1".
- (2) When the first effective edge is input after a count is started, an indeterminate value is transferred to the reload register. At this time, timer Bi interrupt request is not generated.

## Timer X (timer mode)

(1) Reading the timer Xi register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the timer Xi register with the reload timing gets "FFFF16". Reading the timer A0 register after setting a value in the timer Xi register with a count halted but before the counter starts counting gets a proper value.

## Timer X (event counter mode)

- (1) Reading the timer Xi register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the timer Xi register with the reload timing gets "FFFF16" by underflow or "000016" by overflow. Reading the timer Xi register after setting a value in the timer Xi register with a count halted but before the counter starts counting gets a proper value.
- (2) When stop counting in free run type, set timer again.

#### Timer X (one-shot timer mode)

- (1) Setting the count start flag to "0" while a count is in progress causes as follows:
  - The counter stops counting and a content of reload register is reloaded.
  - The TXiINOUT pin outputs "L" level.
  - The interrupt request generated and the timer Xi interrupt request bit goes to "1".
- (2) The timer Xi interrupt request bit goes to "1" if the timer's operation mode is set using any of the following procedures:
  - Selecting one-shot timer mode after reset.
  - Changing operation mode from timer mode to one-shot timer mode.
  - Changing operation mode from event counter mode to one-shot timer mode.

Therefore, to use timer Xi interrupt (interrupt request bit), set timer Xi interrupt request bit to "0" after the above listed changes have been made.

# Timer X (pulse width modulation mode)

- (1) The timer Xi interrupt request bit becomes "1" if setting operation mode of the timer in compliance with any of the following procedures:
  - Selecting PWM mode after reset.
  - Changing operation mode from timer mode to PWM mode.
  - Changing operation mode from event counter mode to PWM mode.

Therefore, to use timer Xi interrupt (interrupt request bit), set timer Xi interrupt request bit to "0" after the above listed changes have been made.

(2) Setting the count start flag to "0" while PWM pulses are being output causes the counter to stop counting. If the TXiINOUT pin is outputting an "H" level in this instance, the output level goes to "L", and the timer Xi interrupt request bit goes to "1". If the TXIINOUT pin is outputting an "L" level in this instance, the level does not change, and the timer Xi interrupt request bit does not becomes "1".

## Timer X (pulse period/pulse width measurement mode)

- (1) If changing the measurement mode select bit is set after a count is started, the timer Xi interrupt request bit goes to "1".
- (2) When the first effective edge is input after a count is started, an indeterminate value is transferred to the reload register. At this time, timer Xi interrupt request is not generated.

#### **A-D Converter**

- (1) Write to each bit (except bit 6) of A-D control register 0, to each bit of A-D control register 1, and to bit 0 of A-D control register 2 when A-D conversion is stopped (before a trigger occurs). In particular, when the Vref connection bit is changed from "0" to "1", start A-D conversion after an elapse of 1 µs or longer.
- (2) When changing A-D operation mode, select analog input pin again.
- (3) Using one-shot mode or single sweep mode Read the correspondence A-D register after confirming A-D conversion is finished. (It is known by A-D conversion interrupt request bit.)
- (4) Using repeat mode, repeat sweep mode 0 or repeat sweep mode 1 Use the undivided main clock as the internal CPU clock.

#### **Stop Mode and Wait Mode**

- (1) When returning from stop mode by hardware reset, RESET pin must be set to "L" level until main clock oscillation is stabilized.
- (2) When shifting to WAIT mode or STOP mode, the program stops after reading 8 bytes from the WAIT instruction and the instruction that sets all clock stop bits to "1" in the instruction queue. Therefore, insert a minimum of 8 NOPs after the WAIT instruction and the instruction that sets all clock stop bits to "1".

#### Interrupts

- (1) Reading address 0000016
  - When maskable interrupt is occurred, CPU read the interrupt information (the interrupt number and interrupt request level) in the interrupt sequence.

The interrupt request bit of the certain interrupt written in address 0000016 will then be set to "0". Reading address 0000016 by software sets enabled highest priority interrupt source request bit to "0".

Though the interrupt is generated, the interrupt routine may not be executed.

Do not read address 0000016 by software.

- (2) Setting the stack pointer
  - The value of the stack pointer immediately after reset is initialized to 000016. Accepting an interrupt before setting a value in the stack pointer may become a factor of runaway. Be sure to set a value in the stack pointer before accepting an interrupt.

Concerning the first instruction immediately after reset, generating any interrupt is prohibited.

- (3) External interrupt
  - When changing a polarity of pins  $\overline{\text{INT0}}$  and  $\overline{\text{INT1}}$ , the interrupt request bit may become "1". Clear the interrupt request bit after changing the polarity.
- (4) Changing interrupt control register

See "Changing Interrupt Control Register".

## **Electrical characteristics**

Table 1.37. Absolute maximum ratings

| Symbol | Parameter                                                                                                               | Condition  | Rated value                    | Unit |
|--------|-------------------------------------------------------------------------------------------------------------------------|------------|--------------------------------|------|
| Vcc    | Supply voltage                                                                                                          |            | - 0.3 to 7                     | V    |
| AVcc   | Analog supply voltage                                                                                                   |            | - 0.3 to 7                     | V    |
| Vı     | Input voltage RESET, CNVss, P0o to P07, P1o to P17, P3o to P35, P4o to P45, P5o to P54, P6o to P67, P70, P71, VREF, XIN |            | - 0.3 to Vcc + 0.3<br>(Note 1) | V    |
| Vo     | Output voltage P0o to P07, P1o to P17, P3o to P35, P4o to P45, P5o to P54, P6o to P67, P70, P71, VREF, XIN              |            | - 0.3 to Vcc + 0.3             | V    |
| Pd     | Power dissipation                                                                                                       | Ta = 25 °C | 1000 (Note 2)                  | mW   |
| Topr   | Operating ambient temperature                                                                                           |            | - 20 to 85 (Note 3)            | °C   |
| Tstg   | Storage temperature                                                                                                     |            | - 40 to 150 (Note 4)           | °C   |

Note 1: When writing to frash MCU, CNVss is –0.3 to 13 (V) .

Note 3: Extended operating temperature version: -40 to 85  $^{\circ}\text{C}.$ 

Note 2: Flat package (56P6S-A) is 300 mW.

Note 4: Extended operating temperature version: -65 to 150  $^{\circ}\text{C}.$ 



Table 1.38. Recommended operating conditions (Note 1)

| Symbol                 | Parameter                      |                                                                                           |                                            | Standard              | 1                       | Unit   |        |                      |      |
|------------------------|--------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------------|-----------------------|-------------------------|--------|--------|----------------------|------|
| Cyllibol               |                                |                                                                                           |                                            |                       |                         | Min    | Тур.   | Max.                 | OTIL |
| Vcc                    | Supply voltage (N              | ote 2)                                                                                    |                                            | Mask                  | ROM version             | 2.7    | 5.0    | 5.5                  | V    |
|                        |                                |                                                                                           |                                            | Flash                 | memory version          | 4.0    | 5.0    | 5.5                  | V    |
| AVcc                   | Analog supply volt             | ipply voltage                                                                             |                                            |                       |                         |        | Vcc    |                      | V    |
| Vss                    | Supply voltage                 |                                                                                           |                                            |                       |                         |        | 0      |                      | V    |
| AVss                   | Analog supply volt             | tage                                                                                      |                                            |                       |                         |        | 0      |                      | V    |
| VIH                    | HIGH input voltage             | P00 to P07, P <sup>.</sup><br>P50 to P54, P6                                              | 10 to P17, P30 to P<br>30 to P67, P70, P7  | P35, P40<br>1, XIN, R | to P45,<br>ESET, CNVss, | 0.8Vcc |        | Vcc                  | V    |
| V <sub>IL</sub>        | LOW input voltage              | P00 to P07, P                                                                             | 10 to P17, P30 to F<br>50 to P67, P70, P71 | P35, P40              | to P45,                 | 0      |        | 0.2Vcc               | V    |
| I OH (peak)            |                                | utput P00 to P07, P10 to P17, P30 to P35, P40 to P45,<br>P50 to P54, P60 to P67, P70, P71 |                                            |                       |                         |        | - 10.0 | mA                   |      |
| I <sub>OL (peak)</sub> | =o poun output                 | •                                                                                         | 30 to P35, P40 to F<br>30 to P67, P70, P7  | •                     |                         |        |        | 10.0                 | mA   |
|                        | LOW peak output P10 to P1      |                                                                                           | 17                                         |                       | HIGHPOWER               |        |        | 30.0                 |      |
| I <sub>OL</sub> (peak) | current                        |                                                                                           |                                            |                       | LOWPOWER                |        |        | 10.0                 | mA   |
| I <sub>OH (avg)</sub>  | HIGH average output<br>current |                                                                                           | 7, P10 to P17, P30<br>54, P60 to P67, P70  |                       | P40 to P45,             |        |        | - 5.0                | mA   |
| IOL (avg)              | LOW average output             | •                                                                                         | 7, P30 to P35, P40<br>54, P60 to P67, P70  |                       |                         |        |        | 5.0                  | mA   |
| I <sub>OL (avg)</sub>  | LOW average outpu              | t P10 to P1                                                                               | 7                                          |                       | HIGHPOWER               |        |        | 15.0                 |      |
| (9)                    | current                        |                                                                                           |                                            |                       | LOWPOWER                |        |        | 5.0                  | mA   |
| f (XIN)                | Main clock input               | Without                                                                                   | Mask ROM vers                              | sion                  | Vcc=4.0V to 5.5V        | 0      |        | 10                   | MHz  |
| 1 (7(114)              | oscillation                    | wait                                                                                      |                                            |                       | Vcc=2.7V to 4.0V        | 0      |        | 5 x Vcc<br>- 10.000  | MHz  |
| frequency              | frequency                      |                                                                                           | Flash memory v                             | ersion                | Vcc=4.0V to 5.5V        | 0      |        | 10                   | MHz  |
|                        |                                | With wait                                                                                 | Mask ROM vers                              | sion                  | Vcc=4.0V to 5.5V        | 0      |        | 10                   | MHz  |
|                        |                                |                                                                                           |                                            |                       | Vcc=2.7V to 4.0V        | 0      |        | 2.31 x Vcc<br>+0.760 | MHz  |
|                        |                                |                                                                                           | Flash memory v                             | ersion                | Vcc=4.0V to 5.5V        | 0      |        | 10                   | MHz  |
| f (Xcin)               | Subclock oscillation           | n frequency                                                                               | •                                          |                       |                         |        | 32.768 | 50                   | kHz  |

Note 1: Unless otherwise noted: Vcc = 2.7V to 5.5V, Vss = 0V, Ta = -20 to  $85^{\circ}C$  (Extended operating temperature version: -40 to  $85^{\circ}C$ ). Flash version: Vcc = 4.0V to 5.5V, Vss = 0V, Ta = -20 to  $85^{\circ}C$  (Extended operating temperature version: -40 to  $85^{\circ}C$ .)

Note 2: Flash version: VCC = 4.0V to 5.5V

Note 3: The average output current is an average value measured over 100ms.

Note 4: Keep output current as follows:

The sum of port P3 and P4 IoL (peak) is under 40 mA. The sum of port P1 IoL (peak) is under 60 mA. The sum of port P1, P3 and P4 IoH (peak) is under 40 mA. The sum of port P0, P5, P6 and P7 IoL (peak) is under 80 mA. The sum of port P0, P5, P6 and P7 IoH (peak) is under 80 mA.





Table 1.39. Electrical characteristics (Note1)

| Cl        | I Parameter          |                                                                                    | Measuring condition                           | S              | Linit                                                 |      |      |       |      |
|-----------|----------------------|------------------------------------------------------------------------------------|-----------------------------------------------|----------------|-------------------------------------------------------|------|------|-------|------|
| Symbol    |                      | Parameter                                                                          |                                               | Mea            | suring condition                                      | Min. | Тур. | Max.  | Unit |
| Vон       | HIGH output voltage  | P00 to P07,P10 to P17,P<br>P40 to P45,P50 to P54,P                                 | D P17,P30 to P35,<br>D P54,P60 to P67,P70,P71 |                | mA                                                    | 3.0  |      |       | V    |
| Vон       | HIGH output voltage  | P00 to P07,P10 to P17,P<br>P40 to P45,P50 to P54,P                                 |                                               | Іон = - 20     | 00 μΑ                                                 | 4.7  |      |       | V    |
| Vон       | HIGH output          | Vour                                                                               | HIGHPOWER                                     | Іон = - 1      | mA                                                    | 3.0  |      |       | V    |
| VOH       | voltage              | Хоит                                                                               | LOWPOWER                                      | Іон = - 0.     | 5 mA                                                  | 3.0  |      |       | V    |
| Vон       | HIGH output          | Хсоит                                                                              | HIGHPOWER                                     | No load        |                                                       |      | 3.0  |       | V    |
| VOIT      | voltage              | ACOUT                                                                              | LOWPOWER                                      | No load        |                                                       |      | 1.6  |       | V    |
| Vol       | LOW output voltage   | P00 to P07,P30 to P35,P<br>P50 to P54,P60 to P67,P                                 |                                               | IoL = 5 m      | A                                                     |      |      | 2.0   | V    |
| Vol       | LOW output voltage   | P00 to P07,P30 to P35,P4<br>P50 to P54,P60 to P67,P                                |                                               | IOL = 200      | μΑ                                                    |      |      | 0.45  | V    |
| Vol       | LOW output           | P10 to P17                                                                         | HIGHPOWER                                     | loL = 15n      | nA                                                    |      |      | 2.0   | .,   |
| 102       | voltage              | 1 10 10 1 17                                                                       | LOWPOWER                                      | IoL = 5 m      | A                                                     |      |      | 2.0   | V    |
|           | LOW output           | P10 to P17                                                                         | HIGHPOWER                                     | IOL = 200      | ) μΑ                                                  |      |      | 0.3   | V    |
| Vol       | voltage              | 1 10 10 1 17                                                                       | LOWPOWER                                      | IOL = 200      | ) μΑ                                                  |      |      | 0.45  | V    |
| Vol       | LOW output voltage   | Хоит                                                                               | HIGHPOWER                                     | Iон = 1 m      | nA                                                    |      |      | 2.0   | .,   |
| VOL       | voitage              |                                                                                    | LOWPOWER                                      | Іон = 0.5      | mA                                                    |      |      | 2.0   | V    |
| 1/        | LOW output           | OW output<br>oltage Хоит                                                           | HIGHPOWER                                     | No load        |                                                       |      | 0    |       |      |
| Vol       | voltage              |                                                                                    | LOWPOWER                                      | No load        |                                                       |      | 0    |       | V    |
| VT+ -VT-  | Hysteresis           | TA0in,TX0inout,TX1ino<br>TB0in,TB1in INTo,INT1,(<br>RxDo, RxD1                     |                                               |                |                                                       | 0.2  |      | 0.8   | V    |
| VT+ -VT-  | Hysteresis           | RESET                                                                              |                                               |                |                                                       | 0.2  |      | 1.8   | V    |
| Іін       | HIGH input current   | P00 to P07,P10 to P17,P<br>P40 to P45,P50 to P54,P<br>P70,P71, RESET, CNVs         | 60 to P67                                     | Vi = 5V        |                                                       |      |      | 5.0   | μA   |
| lıL       | LOW input<br>current | P00 to P07,P10 to P17,P<br>P40 to P4 <u>5,P50 to</u> P54,P<br>P70,P71, RESET, CNVs | 60 to P67,                                    | VI = 0V        |                                                       |      |      | -5.0  | μA   |
| RPULLUP   | Pull-up<br>resistor  | P00 to P07,P10 to P17,P<br>P40 to P45,P50 to P54,P                                 |                                               | Vı = 0V        |                                                       | 30.0 | 50.0 | 167.0 | kΩ   |
| RXIN      | Feedback res         | istor X <sub>IN</sub>                                                              |                                               |                |                                                       |      | 1.0  |       | МΩ   |
| Rxcin     | Feedback res         | istor Xcın                                                                         |                                               |                |                                                       |      | 6.0  |       | МΩ   |
| $V_{RAM}$ | RAM retention        | n voltage                                                                          |                                               | When clo       | ock is stopped                                        | 2.0  | 2.2  |       | V    |
|           |                      |                                                                                    |                                               |                | f(X <sub>IN</sub> )=10MHz<br>Square wave, no division |      | 19.0 | 38.0  | mA   |
|           |                      |                                                                                    |                                               | I/O pin        | f(XCIN)=32kHz<br>Square wave                          |      | 90.0 |       | μА   |
| Icc       | Power supply         | current                                                                            |                                               | has no<br>load | f(XCIN)=32kHz<br>With wait(Note2)<br>Ta=25°C when     |      | 4.0  | 1.0   | μA   |
|           |                      |                                                                                    |                                               |                | clock is stopped Ta=85°C when clock is stopped        |      |      | 20.0  | μA   |

Note 1: Unless otherwise noted: VCC = 5V, VSS = 0V at Ta = 25°C, f(XIN) = 10MHz)

Note 2: With one timer operated using fC32.



Table 1.40. A-D conversion characteristics

| Cumbal        | Downwater  | NA                                      | 8                   | Standard |      |      |      |
|---------------|------------|-----------------------------------------|---------------------|----------|------|------|------|
| Symbol        |            | Parameter                               | Measuring condition | Min.     | Тур. | Max. | Unit |
| _             | Resolution | า                                       | VREF=VCC            |          |      | 10   | Bits |
| _             | Absolute   | Sample & hold function not available    | VREF =VCC = 5V      |          |      | ±3   | LSB  |
|               | accuracy   | Sample & hold function available(10bit) | VREF =VCC= 5V       |          |      | ±3   | LSB  |
|               |            | Sample & hold function available(8bit)  | VREF = VCC = 5V     |          |      | ±2   | LSB  |
| RLADDER       | Ladder re  | sistance                                | VREF =VCC           | 10       |      | 40   | kohm |
| tconv         | Conversion | n time(10bit)                           |                     | 3.3      |      |      | μs   |
| tconv         | Conversio  | n time(8bit)                            |                     | 2.8      |      |      | μs   |
| <b>t</b> SAMP | Sampling   | time                                    |                     | 0.3      |      |      | μs   |
| VREF          | Reference  | e voltage                               |                     | 2        |      | Vcc  | V    |
| VIA           | Analog inp | out voltage                             |                     | 0        |      | VREF | V    |

Timing requirements (referenced to Vcc = 5V, Vss = 0V at Ta = 25°C unless otherwise specified)

Table 1.41. External clock input

| C      |                                       | Star | 1.1  |      |
|--------|---------------------------------------|------|------|------|
| Symbol | Parameter                             | Min. | Max. | Unit |
| tc     | External clock input cycle time       | 100  |      | ns   |
| tw(H)  | External clock input HIGH pulse width | 40   |      | ns   |
| tw(L)  | External clock input LOW pulse width  | 40   |      | ns   |
| tr     | External clock rise time              |      | 15   | ns   |
| tf     | External clock fall time              |      | 15   | ns   |

Table 1.42. Timer A input (counter input in event counter mode)

| O. maked |                              | Star | ndard | Unit  |
|----------|------------------------------|------|-------|-------|
| Symbol   | Parameter                    | Min. | Max.  | Offic |
| tc(TA)   | TA0ın input cycle time       | 100  |       | ns    |
| tw(TAH)  | TA0ın input HIGH pulse width | 40   |       | ns    |
| tw(TAL)  | TA0เท input LOW pulse width  | 40   |       | ns    |

Table 1.43. Timer A input (gating input in timer mode)

|         |                              | Star | Standard |      |
|---------|------------------------------|------|----------|------|
| Symbol  | Parameter                    | Min. | Max.     | Unit |
| tc(TA)  | TA0ın input cycle time       | 400  |          | ns   |
| tw(TAH) | TA0ın input HIGH pulse width | 200  |          | ns   |
| tw(TAL) | TA0in input LOW pulse width  | 200  |          | ns   |

Table 1.44. Timer A input (external trigger input in one-shot timer mode)

|         | 5 .                          | Star | ndard | l lm:4 |
|---------|------------------------------|------|-------|--------|
| Symbol  | Parameter                    | Min. | Max.  | Unit   |
| tc(TA)  | TA0IN input cycle time       | 200  |       | ns     |
| tw(TAH) | TA0ın input HIGH pulse width | 100  |       | ns     |
| tw(TAL) | TA0ın input LOW pulse width  | 100  |       | ns     |

Table 1.45. Timer A input (external trigger input in pulse width modulation mode)

|         |                              | Star | ndard | Unit |
|---------|------------------------------|------|-------|------|
| Symbol  | Parameter                    | Min. | Max.  | Unit |
| tw(TAH) | TA0IN input HIGH pulse width | 100  |       | ns   |
| tw(TAL) | TA0ın input LOW pulse width  | 100  |       | ns   |

Table 1.46. Timer A input (up/down input in event counter mode)

|             | <b>5</b>                      | Sta  | ndard | Linit |
|-------------|-------------------------------|------|-------|-------|
| Symbol      | Parameter                     | Min. | Max.  | Unit  |
| tc(UP)      | TA0out input cycle time       | 2000 |       | ns    |
| tw(UPH)     | TA0out input HIGH pulse width | 1000 |       | ns    |
| tw(UPL)     | TA0out input LOW pulse width  | 1000 |       | ns    |
| tsu(UP-TIN) | TA0out input setup time       | 400  |       | ns    |
| th(TIN-UP)  | TA0out input hold time        | 400  |       | ns    |

Timing requirements (referenced to Vcc = 5V, VSS = 0V at Ta = 25°C unless otherwise specified)

Table 1.47. Timer B input (counter input in event counter mode)

|         | ъ .                                                  | Star | ndard | Unit  |
|---------|------------------------------------------------------|------|-------|-------|
| Symbol  | Parameter                                            | Min. | Max.  | Offic |
| tc(TB)  | ТВім input cycle time (counted on one edge)          | 100  |       | ns    |
| tw(TBH) | ТВіім input HIGH pulse width (counted on one edge)   | 40   |       | ns    |
| tw(TBL) | ТВіім input LOW pulse width (counted on one edge)    | 40   |       | ns    |
| tc(TB)  | ТВіім input cycle time (counted on both edges)       | 200  |       | ns    |
| tw(TBH) | ТВіім input HIGH pulse width (counted on both edges) | 80   |       | ns    |
| tw(TBL) | TBiin input LOW pulse width (counted on both edges)  | 80   |       | ns    |

## Table 1.48. Timer B input (pulse period measurement mode)

| C: make al | Dovernator                  | Star | 00   | Unit  |
|------------|-----------------------------|------|------|-------|
| Symbol     | Parameter                   | Min. | Max. | Offic |
| tc(TB)     | TBin input cycle time       | 400  |      | ns    |
| tw(TBH)    | TBin input HIGH pulse width | 200  |      | ns    |
| tw(TBL)    | TBin input LOW pulse width  | 200  |      | ns    |

## Table 1.49. Timer B input (pulse width measurement mode)

| Symbol  | Parameter                   | Standard Min. Max. |  | Unit |
|---------|-----------------------------|--------------------|--|------|
| tc(TB)  | TBiin input cycle time      | 400                |  | ns   |
| tw(TBH) | TBin input HIGH pulse width | 200                |  | ns   |
| tw(TBL) | TBiin input LOW pulse width | 200                |  | ns   |

#### Table 1.50. Timer X input (counter input in event counter mode)

|         |                                 | Star | Max. | Unit |
|---------|---------------------------------|------|------|------|
| Symbol  | nbol Parameter                  | Min. | Max. | Unit |
| tc(TX)  | TXiiNout input cycle time       | 100  |      | ns   |
| tw(TXH) | TXiINOUT input HIGH pulse width | 40   |      | ns   |
| tw(TXL) | TXiINOUT input LOW pulse width  | 40   |      | ns   |

# Table 1.51. Timer X input (gate input in timer mode)

|         |                                 | Star | ndard | Unit  |
|---------|---------------------------------|------|-------|-------|
| Symbol  | Parameter                       | Min. | Max.  | Offic |
| tc(TX)  | TXiiNout input cycle time       | 400  |       | ns    |
| tw(TXH) | TXiINOUT input HIGH pulse width | 200  |       | ns    |
| tw(TXL) | TXiINOUT input LOW pulse width  | 200  |       | ns    |

#### Table 1.52. Timer X input (external trigger input in one-shot timer mode)

|         | 5                               | Star | ndard | Unit  |
|---------|---------------------------------|------|-------|-------|
| Symbol  | Parameter                       | Min. | Max.  | Offic |
| tc(TX)  | TXiINOUT input cycle time       | 200  |       | ns    |
| tw(TXH) | TXiINOUT input HIGH pulse width | 100  |       | ns    |
| tw(TXL) | TXiINOUT input LOW pulse width  | 100  |       | ns    |

Timing requirements (referenced to Vcc = 5V, Vss = 0V at Ta = 25°C unless otherwise specified)

Table 1.53. Timer X input (pulse period measurement mode)

| Symbol  | 5                               | Star | ndard | Lloit |
|---------|---------------------------------|------|-------|-------|
|         | Parameter                       | Min. | Max.  | ns ns |
| tc(TX)  | TXiiNout input cycle time       | 400  |       | ns    |
| tw(TXH) | TXiINOUT input HIGH pulse width | 200  |       | ns    |
| tw(TXL) | TXiINOUT input LOW pulse width  | 200  |       | ns    |

Table 1.54. Timer X input (pulse width measurement mode)

|         | 5 .                             | Star | ndard | Unit |
|---------|---------------------------------|------|-------|------|
| Symbol  | Parameter                       | Min. | Max.  | Unit |
| tc(TX)  | TXiINOUT input cycle time       | 400  |       | ns   |
| tw(TXH) | TXiINOUT input HIGH pulse width | 200  |       | ns   |
| tw(TXL) | TXiINOUT input LOW pulse width  | 200  |       | ns   |

#### Table 1.55. Serial I/O

|          | 5                           | Standard | ndard | Unit |
|----------|-----------------------------|----------|-------|------|
| Symbol   | Parameter                   | Min.     | Max.  |      |
| tc(CK)   | CLK0 input cycle time       | 200      |       | ns   |
| tw(CKH)  | CLK0 input HIGH pulse width | 100      |       | ns   |
| tw(CKL)  | CLK0 input LOW pulse width  | 100      |       | ns   |
| td(C-Q)  | TxDi output delay time      |          | 80    | ns   |
| th(C-Q)  | TxDi hold time              | 0        |       | ns   |
| tsu(D-C) | RxDi input setup time       | 30       |       | ns   |
| th(C-D)  | RxDi input hold time        | 90       |       | ns   |

Table 1.56. External interrupt INTi inputs

|         |                             | Standard |      | Unit  |
|---------|-----------------------------|----------|------|-------|
| Symbol  | Parameter                   | Min.     | Max. | Offic |
| tw(INH) | INTi input HIGH pulse width | 250      |      | ns    |
| tw(INL) | INTi input LOW pulse width  | 250      |      | ns    |





Table 1.57. Electrical characteristics (Note 1)

| Symbol           | Parameter Measuring conditi |                                                                                   | curing condition                                                  |             | Standar                                                          |      | Unit  |       |      |
|------------------|-----------------------------|-----------------------------------------------------------------------------------|-------------------------------------------------------------------|-------------|------------------------------------------------------------------|------|-------|-------|------|
| Symbol           |                             | Parameter                                                                         |                                                                   | ivieas      |                                                                  | Min. | Тур.  | Max.  | Unit |
| Vон              | HIGH output voltage         | P00 to P07,P10 to P17,<br>P40 to P45,P50 to P54,                                  |                                                                   | lон = - 1n  | nA                                                               | 2.5  |       |       | V    |
| Vон              | HIGH output                 | Vour                                                                              | HIGHPOWER                                                         | Іон = - 1 і | mA                                                               | 2.5  |       |       | .,   |
| VOH              | voltage                     | Xout                                                                              | LOWPOWER                                                          | Іон = - 50  | μΑ                                                               | 2.5  |       |       | V    |
| Vон              | HIGH output                 | Vacut                                                                             | HIGHPOWER                                                         | No load     |                                                                  |      | 3.0   | 5.0   |      |
| VOH              | voltage                     | Хсоит                                                                             | LOWPOWER                                                          | No load     |                                                                  |      | 1.6   |       | V    |
| Vol              | LOW output voltage          | P00 to P07,P30 to P35,I<br>P50 to P54,P60 to P67,I                                |                                                                   | IOL = 1 m.  | A                                                                |      |       | 0.5   | V    |
| Vol              | LOW output                  | P10 to P17                                                                        | HIGHPOWER                                                         | IoL = 3 m   | A                                                                |      |       | 0.5   |      |
| VOL              | voltage                     | P10 10 P17                                                                        | LOWPOWER                                                          | IOL = 1 m   | A                                                                |      |       | 0.5   | V    |
|                  | LOW output                  | HIGHPOWER                                                                         | Іон = 0.1                                                         | mA          |                                                                  |      | 0.5   |       |      |
| Vol              | voltage                     | Xout                                                                              | LOWPOWER                                                          | Іон = 50 і  | AL                                                               |      |       | 0.5   | V    |
|                  | LOW output                  |                                                                                   | HIGHPOWER                                                         | No load     |                                                                  |      | 0     | 0.0   |      |
| Vol              | voltage                     | Xout                                                                              | LOWPOWER                                                          | No load     |                                                                  |      | 0     |       | V    |
| VT+ -VT-         | Hysteresis                  | TA0in,TX0inout,TX1in<br>TB0in,TB1in INTo,INT<br>RxD0, RxD1                        |                                                                   |             |                                                                  | 0.2  |       | 0.8   | V    |
| VT+ -VT-         | Hysteresis                  | RESET                                                                             |                                                                   |             |                                                                  | 0.2  |       | 1.8   | V    |
| Іін              | HIGH input current          | P00 to P07,P10 to P17,<br>P40 to P4 <u>5,P50 to</u> P54,<br>P70,P71, RESET, CNV   | P60 to P67,                                                       | Vı = 3V     |                                                                  |      |       | 4.0   | μA   |
| lıL              | LOW input current           | P00 to P07,P10 to P17,I<br>P40 to P4 <u>5,P50 to</u> P54,I<br>P70,P71, RESET, CNV | P60 to P67,                                                       | Vi = 0V     |                                                                  |      |       | -4.0  | μA   |
| RPULLUP          | Pull-up<br>resistor         | P00 to P07,P10 to P17,<br>P40 to P45,P50 to P54,                                  |                                                                   | Vı = 0V     |                                                                  | 66.0 | 120.0 | 500.0 | kΩ   |
| Rxin             | Feedback resi               | istor XIN                                                                         |                                                                   |             |                                                                  |      | 3.0   |       | МΩ   |
| Rxin             | Feedback res                | istor XIN                                                                         |                                                                   |             |                                                                  |      | 10.0  |       | MΩ   |
| V <sub>RAM</sub> | RAM retention               | n voltage                                                                         |                                                                   | When clo    | ock is stopped                                                   | 2.0  |       |       | V    |
|                  |                             |                                                                                   |                                                                   |             | f(X <sub>IN</sub> )=7MHz<br>Square wave, no division             |      | 6.0   | 15.0  | mA   |
|                  |                             |                                                                                   |                                                                   |             | f(XCIN)=32kHz<br>Square wave                                     |      | 40.0  |       | μA   |
|                  |                             | I/O pin                                                                           | f(XCIN)=32kHz<br>With wait.<br>Oscillation capacity HIGH (Note 2) |             | 2.8                                                              |      | μA    |       |      |
| Icc              | Power supply                | current                                                                           |                                                                   | load        | f(XCIN)=32kHz<br>With wait.<br>Oscillation capacity LOW (Note 2) |      | 0.9   |       | μA   |
|                  |                             |                                                                                   |                                                                   |             | Ta=25°C when clock is stopped                                    |      |       | 1.0   | μA   |
|                  |                             |                                                                                   |                                                                   |             | Ta=85°C when clock is stopped                                    |      |       | 20.0  | μΛ   |

Note 1: Unless otherwise noted: VCC = 3V, VSS = 0V at Ta = 25°C, f(XIN) = 7MHz, with wait)

Note 2: With one timer operated using fC32.

Table 1.58. A-D conversion characteristics

| Cymbol  | Dovometer         | Manageria a condition                       | Standard                       |      |      | Unit |       |
|---------|-------------------|---------------------------------------------|--------------------------------|------|------|------|-------|
| Symbol  |                   | Parameter                                   | Measuring condition            | Min. | Тур. | Max. | Offic |
| _       | Resolution        | า                                           | Vref =Vcc                      |      |      | 10   | Bits  |
| _       | Absolute accuracy | Sample & hold function not available (8bit) | VREF =VCC = 3V,<br>ØAD = fAD/2 |      |      | ±2   | LSB   |
| RLADDER | Ladder res        | sistance                                    | VREF =VCC                      | 10   |      | 40   | kohm  |
| tconv   | Conversio         | n time(8bit)                                |                                | 14.0 |      |      | μs    |
| VREF    | Reference         | e voltage                                   |                                | 2.7  |      | Vcc  | V     |
| VIA     | Analog inp        | out voltage                                 |                                | 0    |      | VREF | V     |

# Timing requirements (referenced to Vcc = 3V, Vss = 0V at Ta = 25°C unless otherwise specified)

Table 1.59. External clock input

|        | Parameter                             | Standard |      | I Imia |
|--------|---------------------------------------|----------|------|--------|
| Symbol |                                       | Min.     | Max. | Unit   |
| tc     | External clock input cycle time       | 143      |      | ns     |
| tw(H)  | External clock input HIGH pulse width | 60       |      | ns     |
| tw(L)  | External clock input LOW pulse width  | 60       |      | ns     |
| tr     | External clock rise time              |          | 18   | ns     |
| tf     | External clock fall time              |          | 18   | ns     |

Table 1.60. Timer A input (counter input in event counter mode)

|         | ъ.                           | Standard |      | Unit  |
|---------|------------------------------|----------|------|-------|
| Symbol  | Parameter                    | Min.     | Max. | Offic |
| tc(TA)  | TA0IN input cycle time       | 150      |      | ns    |
| tw(TAH) | TA0IN input HIGH pulse width | 60       |      | ns    |
| tw(TAL) | TA0IN input LOW pulse width  | 60       |      | ns    |

## Table 1.61. Timer A input (gating input in timer mode)

|         |                              | Standard |      | Unit |
|---------|------------------------------|----------|------|------|
| Symbol  | Parameter                    | Min.     | Max. | Unit |
| tc(TA)  | TA0IN input cycle time       | 600      |      | ns   |
| tw(TAH) | TA0IN input HIGH pulse width | 300      |      | ns   |
| tw(TAL) | TA0IN input LOW pulse width  | 300      |      | ns   |

#### Table 1.62. Timer A input (external trigger input in one-shot timer mode)

| 0       |                              | Standard |      | Linit |
|---------|------------------------------|----------|------|-------|
| Symbol  | Parameter                    | Min.     | Max. | Unit  |
| tc(TA)  | TA0ın input cycle time       | 300      |      | ns    |
| tw(TAH) | TA0ın input HIGH pulse width | 150      |      | ns    |
| tw(TAL) | TA0ın input LOW pulse width  | 150      |      | ns    |

## Table 1.63. Timer A input (external trigger input in pulse width modulation mode)

|         |                              |      | Standard |      |
|---------|------------------------------|------|----------|------|
| Symbol  | Parameter                    | Min. | Max.     | Unit |
| tw(TAH) | TA0ın input HIGH pulse width | 150  |          | ns   |
| tw(TAL) | TA0ın input LOW pulse width  | 150  |          | ns   |

#### Table 1.64. Timer A input (up/down input in event counter mode)

|             | Parameter                     | Standard |      | 1.1  |
|-------------|-------------------------------|----------|------|------|
| Symbol      |                               | Min.     | Max. | Unit |
| tc(UP)      | TA0out input cycle time       | 3000     |      | ns   |
| tw(UPH)     | TA0ουτ input HIGH pulse width | 1500     |      | ns   |
| tw(UPL)     | TA0ouT input LOW pulse width  | 1500     |      | ns   |
| tsu(UP-TIN) | TA0out input setup time       | 600      |      | ns   |
| th(TIN-UP)  | TA0out input hold time        | 600      |      | ns   |

Timing requirements (referenced to Vcc = 3V, Vss = 0V at Ta = 25°C unless otherwise specified)

Table 1.65. Timer B input (counter input in event counter mode)

|         | 5 .                                                  | Star | Standard |      |  |
|---------|------------------------------------------------------|------|----------|------|--|
| Symbol  | Parameter                                            | Min. | Max.     | Unit |  |
| tc(TB)  | TBil input cycle time (counted on one edge)          | 150  |          | ns   |  |
| tw(TBH) | TBiin input HIGH pulse width (counted on one edge)   | 60   |          | ns   |  |
| tw(TBL) | TBiin input LOW pulse width (counted on one edge)    | 60   |          | ns   |  |
| tc(TB)  | TBiin input cycle time (counted on both edges)       | 300  |          | ns   |  |
| tw(TBH) | TBiin input HIGH pulse width (counted on both edges) | 160  |          | ns   |  |
| tw(TBL) | TBiin input LOW pulse width (counted on both edges)  | 160  |          | ns   |  |

#### Table 1.66. Timer B input (pulse period measurement mode)

|         | <b>D</b> 4                  | Standard |      | Unit  |
|---------|-----------------------------|----------|------|-------|
| Symbol  | Parameter                   |          | Max. | Offic |
| tc(TB)  | TBin input cycle time       | 600      |      | ns    |
| tw(TBH) | TBin input HIGH pulse width | 300      |      | ns    |
| tw(TBL) | TBin input LOW pulse width  | 300      |      | ns    |

## Table 1.67. Timer B input (pulse width measurement mode)

| Symbol  | Parameter                    | Standard Min. Max. |  | Unit |
|---------|------------------------------|--------------------|--|------|
| tc(TB)  | TBiin input cycle time       | 600                |  | ns   |
| tw(TBH) | TBiin input HIGH pulse width | 300                |  | ns   |
| tw(TBL) | TBiin input LOW pulse width  | 300                |  | ns   |

## Table 1.68. Timer X input (counter input in event counter mode)

|         | Parameter                       |     | Standard |      |
|---------|---------------------------------|-----|----------|------|
| Symbol  |                                 |     | Max.     | Unit |
| tc(TX)  | TXiiNOUT input cycle time       | 150 |          | ns   |
| tw(TXH) | TXiiNO∪⊤ input HIGH pulse width | 60  |          | ns   |
| tw(TXL) | TXiINOUT input LOW pulse width  | 60  |          | ns   |

## Table 1.69. Timer X input (gate input in timer mode)

|         | Parameter                       |     | Standard |      |
|---------|---------------------------------|-----|----------|------|
| Symbol  |                                 |     | Max.     | Unit |
| tc(TX)  | TXiινουτ input cycle time       | 600 |          | ns   |
| tw(TXH) | TXiINOUT input HIGH pulse width | 300 |          | ns   |
| tw(TXL) | TXiiNOUT input LOW pulse width  | 300 |          | ns   |

#### Table 1.70. Timer X input (external trigger input in one-shot timer mode)

| Cumbal  | hal Davamatau                   |      | Standard |      |
|---------|---------------------------------|------|----------|------|
| Symbol  | Parameter                       | Min. | Max.     | Unit |
| tc(TX)  | TXiINOUT input cycle time       | 300  |          | ns   |
| tw(TXH) | TXiINOUT input HIGH pulse width | 150  |          | ns   |
| tw(TXL) | TXiNOUT input LOW pulse width   | 150  |          | ns   |

Timing requirements (referenced to Vcc = 3V, Vss = 0V at Ta = 25°C unless otherwise specified)

Table 1.71. Timer X input (pulse period measurement mode)

|         | Parameter -                     |     | Standard |      |
|---------|---------------------------------|-----|----------|------|
| Symbol  |                                 |     | Max.     | Unit |
| tc(TX)  | TXiiNou⊤ input cycle time       | 600 |          | ns   |
| tw(TXH) | TXiINOUT input HIGH pulse width | 300 |          | ns   |
| tw(TXL) | TXiINOUT input LOW pulse width  | 300 |          | ns   |

Table 1.72. Timer X input (pulse width measurement mode)

|         | pol Parameter                   |     | Standard |      |
|---------|---------------------------------|-----|----------|------|
| Symbol  |                                 |     | Max.     | Unit |
| tc(TX)  | TXiINOUT input cycle time       | 600 |          | ns   |
| tw(TXH) | TXiINOUT input HIGH pulse width | 300 |          | ns   |
| tw(TXL) | TXiINOUT input LOW pulse width  | 300 |          | ns   |

Table 1.73. Serial I/O

|          | _                           | Standard |      | I Imit |
|----------|-----------------------------|----------|------|--------|
| Symbol   | Parameter                   |          | Max. | Unit   |
| tc(CK)   | CLK0 input cycle time       | 300      |      | ns     |
| tw(CKH)  | CLK0 input HIGH pulse width | 150      |      | ns     |
| tw(CKL)  | CLK0 input LOW pulse width  | 150      |      | ns     |
| td(C-Q)  | TxDi output delay time      |          | 160  | ns     |
| th(C-Q)  | TxDi hold time              | 0        |      | ns     |
| tsu(D-C) | RxDi input setup time       | 50       |      | ns     |
| th(C-D)  | RxDi input hold time        | 90       |      | ns     |

Table 1.74. External interrupt INTi inputs

|         | mbol Parameter              |     | Standard |      |
|---------|-----------------------------|-----|----------|------|
| Symbol  |                             |     | Max.     | Unit |
| tw(INH) | INTi input HIGH pulse width | 380 |          | ns   |
| tw(INL) | INTi input LOW pulse width  | 380 |          | ns   |







#### **Outline Performance**

Table AA-1 shows the outline performance of the M30201 (flash memory version).

Table AA-1. Outline Performance of the M30201 (flash memory version)

|                              | Item          | Performance                                                  |
|------------------------------|---------------|--------------------------------------------------------------|
| Power supply vol             | tage          | 4.0V to 5.5 V (f(XIN)=10MHz)                                 |
| Program/erase vo             | oltage        | VPP=12V ± 5% (f(XIN)=10MHz)                                  |
|                              |               | $VCC=5V \pm 5\% (f(XIN)=10MHz)$                              |
| Flash memory operation mode  |               | Three modes (parallel I/O, standard serial I/O, CPU rewrite) |
| Erase block                  | User ROM area | See Figure 1.AA.3.                                           |
| division                     | Boot ROM area | One division (4 Kbytes) (Note 1)                             |
| Program method               |               | In units of byte                                             |
| Erase method                 |               | Collective erase                                             |
| Program/erase control method |               | Program/erase control by software command                    |
| Number of commands           |               | 6 commands                                                   |
| Program/erase count          |               | 100 times                                                    |
| ROM code protect             | et            | Parallel I/O mode is supported.                              |

Note: The boot ROM area contains a standard serial I/O mode control program which is stored in it when shipped from the factory. This area can be erased and programmed in only parallel I/O mode.



## **Flash Memory**

The M30201 (flash memory version) contains the NOR type of flash memory that requires a high-voltage VPP power supply for program/erase operations, in addition to the VCC power supply for device operation. For this flash memory, three flash memory modes are available in which to read, program, and erase: parallel I/O and standard serial I/O modes in which the flash memory can be manipulated using a programmer and a CPU rewrite mode in which the flash memory can be manipulated by the Central Processing Unit (CPU). Each mode is detailed in the pages to follow.

In addition to the ordinary user ROM area to store a microcomputer operation control program, the flash memory has a boot ROM area that is used to store a program to control rewriting in CPU rewrite and standard serial I/O modes. This boot ROM area has had a standard serial I/O mode control program stored in it when shipped from the factory. However, the user can write a rewrite control program in this area that suits the user's application system. This boot ROM area can be rewritten in only parallel I/O mode.



Figure AA-3. Block diagram of flash memory version



#### **CPU Rewrite Mode**

In CPU rewrite mode, the on-chip flash memory can be operated on (read, program, or erase) under control of the Central Processing Unit (CPU). In CPU rewrite mode, the flash memory can be operated on by reading or writing to the flash memory control register and flash command register. Figure BB-1, Figure BB-2 show the flash memory control register, and flash command register respectively.

Also, in CPU rewrite mode, the CNVss pin is used as the VPP power supply pin. Apply the power supply voltage, VPPH, from an external source to this pin.

In CPU rewrite mode, only the user ROM area shown in Figure AA-3 can be rewritten; the boot ROM area cannot be rewritten. Make sure the program and block commands are issued for only the user ROM area. The control program for CPU rewrite mode can be stored in either user ROM or boot ROM area. In the CPU rewrite mode, because the flash memory cannot be read from the CPU, the rewrite control program must be transferred to internal RAM before it can be executed.



Figure BB-1. Flash memory control register



Figure BB-2. Flash command register



## Microcomputer Mode and Boot Mode

The control program for CPU rewrite mode must be written into the user ROM or boot ROM area in parallel I/O mode beforehand. (If the control program is written into the boot ROM area, the standard serial I/O mode becomes unusable.)

See Figure AA-3 for details about the boot ROM area.

Normal microcomputer mode is entered when the microcomputer is reset with pulling CNVss pin low (Vss). In this case, the CPU starts operating using the control program in the user ROM area.

When the microcomputer is reset by pulling the P52 pin high (Vcc), the CNVss pin high(VPPH), the CPU starts operating using the control program in the boot ROM area. This mode is called the "boot" mode. The control program in the boot ROM area can also be used to rewrite the user ROM area.

## CPU rewrite mode operation procedure

The internal flash memory can be operated on to program, read, verify, or erase it while being placed on-board by writing commands from the CPU to the flash memory control register (addresses 03B416, 03B516) and flash command register (address 03B616). Note that when in CPU rewrite mode, the boot ROM area cannot be accessed for program, read, verify, or erase operations. Before this can be accomplished, a CPU write control program must be written into the boot ROM area in parallel input/output mode. The following shows a CPU rewrite mode operation procedure.

## <Start procedure (Note 1)>

- (1) Apply VPPH to the CNVss/VPP pin and VCC to the port P52 pin for reset release. Or the user can jump from the user ROM area to the boot ROM area using the JMP instruction and execute the CPU write control program. In this case, set the CPU write mode select bit of the flash memory control register to "1" before applying VPPH to the CNVss/VPP pin.
- (2) After transferring the CPU write control program from the boot ROM area to the internal RAM, jump to this control program in RAM. (The operations described below are controlled by this program.)
- (3) Set the CPU rewrite mode select bit to "1".
- (4) Read the CPU rewrite mode monitor flag to see that the CPU rewrite mode is enabled.
- (5) Execute operation on the flash memory by writing software commands to the flash command register.

Note 1: In addition to the above, various other operations need to be performed, such as for entering the data to be written to flash memory from an external source (e.g., serial I/O), initializing the ports, and writing to the watchdog timer.

#### <Clearing procedure>

- (1) Apply Vss to the CNVss/VPP pin.
- (2) Set the CPU rewrite mode select bit to "0".

#### **Precautions on CPU Rewrite Mode**

Described below are the precautions to be observed when rewriting the flash memory in CPU rewrite mode.

#### (1) Operation speed

During erase/program mode, set BCLK to one of the following frequencies by changing the divide ratio:

5 MHz or less when wait bit (bit 7 at address 000516) = 0 (without internal access wait state)

10 MHz or less when wait bit (bit 7 at address 000516) = 1 (with internal access wait state)

#### (2) Instructions inhibited against use

The instructions listed below cannot be used during CPU rewrite mode because they refer to the internal data of the flash memory:

UND instruction, INTO instruction, JMPS instruction, JSRS instruction, and BRK instruction

#### (3) Interrupts inhibited against use

No interrupts can be used that look up the fixed vector table in the flash memory area. Maskable interrupts may be used by setting the interrupt vector table in a location outside the flash memory area.

#### **Software Commands**

Table BB-1 lists the software commands available with the M30201 (flash memory version).

When CPU rewrite mode is enabled, write software commands to the flash command register to specify the operation to erase or program.

The content of each software command is explained below.

Table BB-1. List of Software Commands (CPU Rewrite Mode)

|                | F     | irst bus cyc       | /cle                                        |       |                   |                                             |
|----------------|-------|--------------------|---------------------------------------------|-------|-------------------|---------------------------------------------|
| Command        | Mode  | Address            | Data<br>(D <sub>0</sub> to D <sub>7</sub> ) | Mode  | Address           | Data<br>(D <sub>0</sub> to D <sub>7</sub> ) |
| Read           | Write | 03B616             | 0016                                        |       |                   |                                             |
| Program        | Write | 03B6 <sub>16</sub> | 4016                                        | Write | Program address   | Program<br>data                             |
| Program verify | Write | 03B616             | C016                                        | Read  | Verify<br>address | Verify<br>data                              |
| Erase          | Write | 03B616             | 2016                                        | Write | 03B616            | 2016                                        |
| Erase verify   | Write | 03B616             | A016                                        | Read  | Verify address    | Verify<br>data                              |
| Reset          | Write | 03B616             | FF16                                        | Write | 03B616            | FF16                                        |

#### Read Command (0016)

The read mode is entered by writing the command code "0016" to the flash command register in the first bus cycle. When an address to be read is input in one of the bus cycles that follow, the content of the specified address is read out at the data bus (D0–D7), 8 bits at a time.

The read mode is retained intact until another command is written.

After reset and after the reset command is executed, the read mode is set.

#### **Program Command (4016)**

The program mode is entered by writing the command code "4016" to the flash command register in the first bus cycle. When the user execute an instruction to write byte data to the desired address (e.g., STE instruction) in the second bus cycle, the flash memory control circuit executes the program operation. The program operation requires approximately 20  $\mu$ s. Wait for 20  $\mu$ s or more before the user go to the next processing.

During program operation, the watchdog timer remains idle, with the value "7FFF16" set in it.

Note 1: The write operation is not completed immediately by writing a program command once. The user must always execute a program-verify command after each program command executed. And if verification fails, the user need to execute the program command repeatedly until the verification passes. See Figure 1.BB.3 for an example of a programming flowchart.



#### Program-verify command (C0<sub>16</sub>)

The program-verify mode is entered by writing the command code "C016" to the flash command register in the first bus cycle. When the user execute an instruction (e.g., LDE instruction) to read byte data from the address to be verified (the previously programmed address) in the second bus cycle, the content that has actually been written to the address is read out from the memory.

The CPU compares this read data with the data that it previously wrote to the address using the program command. If the compared data do not match, the user need to execute the program and program-verify operations one more time.

#### Erase command (2016 + 2016)

The flash memory control circuit executes an erase operation by writing command code "2016" to the flash command register in the first bus cycle and the same command code to the flash command register again in the second bus cycle. The erase operation requires approximately 20 ms. Wait for 20 ms or more before the user go to the next processing.

Before this erase command can be performed, all memory locations to be erased must have had data "0016" written to by using the program and program-verify commands. During erase operation, the watchdog timer remains idle, with the value "7FFF16 set in it.

Note 1: The erase operation is not completed immediately by writing an erase command once. The user must always execute an erase-verify command after each erase command executed. And if verification fails, the user need to execute the erase command repeatedly until the verification passes. See Figure BB-3 for an example of an erase flowchart.

#### Erase-verify command (A016)

The erase-verify mode is entered by writing the command code "A016" to the flash command register in the first bus cycle. When the user execute an instruction to read byte data from the address to be verified (e.g., LDE instruction) in the second bus cycle, the content of the address is read out.

The CPU must sequentially erase-verify memory contents one address at a time, over the entire area erased. If any address is encountered whose content is not "FF16" (not erased), the CPU must stop erase-verify at that point and execute erase and erase-verify operations one more time.

Note 1: If any unerased memory location is encountered during erase-verify operation, be sure to execute erase and erase-verify operations one more time. In this case, however, the user does not need to write data "0016" to memory before erasing.

#### Reset command (FF16 + FF16)

The reset command is used to stop the program command or the erase command in the middle of operation. After writing command code "4016" or "2016" twice to the flash command register, write command code "FF16" to the flash command register in the first bus cycle and the same command code to the flash command register again in the second bus cycle. The program command or erase command is disabled, with the flash memory placed in read mode.



Figure BB-3. Program and erase execution flowchart in the CPU rewrite mode

### **Description of Pin Function (Flash Memory Parallel I/O Mode)**

| Pin name      | Signal name                   | I/O | Function                                                                                |
|---------------|-------------------------------|-----|-----------------------------------------------------------------------------------------|
| Vcc,Vss       | Power supply input            |     | Apply 5 V ± 10 % to the Vcc pin and 0 V to the Vss pin.                                 |
| CNVss         | CNVss                         | I   | Apply 12 V ± 5 % to the CNVss pin.                                                      |
| RESET         | Reset input                   | I   | Connect this pin to Vss.                                                                |
| XIN           | Clock input                   | I   | Connect a ceramic or crystal resonator between the XIN and XOUT pins.                   |
| Xout          | Clock output                  | 0   | When entering an externally derived clock, enter it from XIN and leave XOUT open.       |
| AVcc, AVss    | Analog power supply input     |     | Connect AVss to Vss and AVcc to Vcc, respectively.                                      |
| VREF          | Reference voltage input       | ı   | Connect this pin to Vss.                                                                |
| P00 to P07    | Data I/O Do to D7             | I/O | These are data Do-D7 input/output pins.                                                 |
| P10 to P17    | Address input A8 to A15       | ı   | These are address A8–A15 input pins.                                                    |
| P30 to P33    | Address input A4 to A7        | I   | These are address A4–A7 input pins.                                                     |
| P34 to P35    | Input port P3                 | I   | Enter low signals to these pins.                                                        |
| P40           | WE input                      | I   | This is a WE input pin.                                                                 |
| P41           | OE input                      | I   | This is a OE input pin.                                                                 |
| P43           | CE input                      | I   | This is a CE input pin.                                                                 |
| P42, P44, P45 | Input port P4                 | I   | Enter high signals or low signals to these pins.                                        |
| P50           | Address input A <sub>17</sub> | Ţ   | This is address A <sub>17</sub> input pin.                                              |
| P51           | VRFY input                    | I   | Apply ViH (5 V) to this pin when VPP = VPPH (12 V), or VIL (0 V) when VPP = VPPL (5 V). |
| P52           | Input port P5                 | 1   | Enter low signal to this pin.                                                           |
| P53, P54      | Input port P5                 | i   | Enter high signals or low signals to these pins.                                        |
| P60 to P63    | Address input Ao to A3        | I   | These are address A0-A3 input pins.                                                     |
| P64 to P67    | Input port P6                 | I   | Enter high signals or low signals to these pins.                                        |
| P70 to P71    | Input port P7                 | I   | Enter high signals or low signals to these pins.                                        |

#### Parallel I/O Mode

The parallel I/O mode is entered by making connections shown in Figures CC-2 and CC-3 and then turning the VPPH power supply on. In this mode, the M30201 (flash memory version) operates in a manner similar to the NOR flash memory M5M28F101 from Mitsubishi. Note, however, that there are some differences with regard to the functions not available with the microcomputer (function of read device identification code) and matters related to memory capacity.

Table CC-2 shows pin relationship between the M30201 and M5M28F101 in parallel I/O mode.

Table CC-2. Pin relationship in parallel I/O mode

|                   | M30201(flash memory version)               | M5M28F101      |
|-------------------|--------------------------------------------|----------------|
| Vcc               | Vcc                                        | Vcc            |
| Vss               | Vss                                        | Vss            |
| Address input     | P60 to P63, P30 to P33,<br>P10 to P17, P50 | A0 to A15, A17 |
| Data I/O          | P00 to P07                                 | Do to D7       |
| OE input          | P41                                        | ŌĒ             |
| CE input          | P43                                        | CE             |
| WE input          | P40                                        | WE             |
| VRFY input (Note) | P51                                        |                |

Note: The VRFY input only selects read-only or read/write mode, and does not have any pin associated with it on the M5M28F101.



Figure CC-1. Block diagram of flash memory version



Figure CC-2. Pin connection diagram in parallel I/O mode (1)



Figure CC-3. Pin connection diagram in parallel I/O mode (2)

#### **User ROM and Boot ROM Areas**

In parallel I/O mode, the user ROM and boot ROM areas shown in Figure CC-1 can be rewritten. In the boot ROM area, an erase block operation is applied to only one 4 K byte block. The boot ROM area has had a standard serial I/O mode control program stored in it when shipped from the Mitsubishi factory. Therefore, using the device in standard serial input/output mode, the user does not need to write to the boot ROM area.

#### **Functional Outline (Parallel I/O Mode)**

In parallel I/O mode, bus operation modes—Read, Output Disable, Standby, and Write—are selected by the status of the  $\overline{CE}$ ,  $\overline{OE}$ ,  $\overline{WE}$ , VRFY, and CNVss input pins.

The contents of erase, program, and other operations are selected by writing a software command. The data in memory can only be read out by a read after software command input.

Program and erase operations are controlled using software commands.

Table CC-3. Relationship between control signals and bus operation modes

| Mode           | Pin name        | CE  | ŌE  | WE  | VRFY | VPP  | Do to D7    |
|----------------|-----------------|-----|-----|-----|------|------|-------------|
| Deed           | Read            | VIL | VIL | ViH | VIL  | VPPH | Data output |
| Read<br>only   | Output disabled | VIL | VIH | VIH | VIL  | VPPH | Hi-Z        |
| 0,             | Stand by        | Vih | X   | Х   | VIL  | VPPH | Hi-Z        |
|                | Read            | VIL | VIL | VIH | VIH  | VPPH | Data output |
| Read/<br>Write | Output disabled | VIL | VIH | VIH | VIH  | VPPH | Hi-Z        |
| VVIILE         | Stand by        | ViH | Х   | X   | VIH  | VPPH | Hi-Z        |
|                | Write           | VIL | VIH | VIL | ViH  | VPPH | Data input  |

Note: X can be VIL or VIH.

The following explains about bus operation modes, software commands, and status register.

#### **Bus Operation Modes**

Read-only mode is entered by applying VPPH to the CNVss pin and a low voltage to the VRFY pin. Read-only mode has three states: Read, Output Disable, and Standby which are selected by setting the  $\overline{\text{CE}}$ ,  $\overline{\text{OE}}$ , and  $\overline{\text{WE}}$  pins high or low.

Read-write mode is entered by applying VPPH to the CNVss pin and a high voltage to the VRFY pin. Read-write mode has four states: Read, Output Disable, Standby, and Write which are selected by setting the  $\overline{\text{CE}}$ ,  $\overline{\text{OE}}$ , and  $\overline{\text{WE}}$  pins high or low.

#### Read

The Read mode is entered by pulling the  $\overline{WE}$  pin high when the  $\overline{CE}$  and  $\overline{OE}$  pins are low. In Read mode, the data corresponding to each software command entered is output from the data I/O pins D0–D7.

#### **Output Disable**

The Output Disable mode is entered by pulling the  $\overline{CE}$  pin low and the  $\overline{WE}$  and  $\overline{OE}$  pins high. Also, the data I/O pins are placed in the high-impedance state.

#### Standby

The Standby mode is entered by driving the  $\overline{CE}$  pin high. Also, the data I/O pins are placed in the high-impedance state.

#### Write

The Write mode is entered by applying VPPH to the CNVss pin and a high voltage to the VRFY pin and then pulling the  $\overline{WE}$  pin low when the  $\overline{CE}$  pin is low and  $\overline{OE}$  pin is high. In this mode, the device accepts the software commands or write data entered from the data I/O pins. A program, erase, or some other operation is initiated depending on the content of the software command entered here. The input data such as address is latched at the falling edge of  $\overline{WE}$  pin. The input data such as software command is latched at the rising edge of  $\overline{WE}$  pin.

#### **Software Commands**

Table CC-4 lists the software commands available with the M30201 (flash memory version). By entering a software command from the data I/O pins (D0–D7) in Write mode, specify the content of the operation, such as erase or program operation, to be performed.

The following explains the content of each software command.

Table CC-4. Software command list (parallel I/O mode)

|                | F     | irst bus cyc   | ele                                         | Second bus cycle |                 |                    |  |
|----------------|-------|----------------|---------------------------------------------|------------------|-----------------|--------------------|--|
| Command        | Mode  | Address        | Data<br>(D <sub>0</sub> to D <sub>7</sub> ) | Mode             | Address         | Data<br>(Do to D7) |  |
| Read           | Write | Х              | 0016                                        |                  |                 |                    |  |
| Program        | Write | Х              | 4016                                        | Write            | Program address | Program<br>data    |  |
| Program verify | Write | Х              | C016                                        | Read             | х               | Verify<br>data     |  |
| Erase          | Write | х              | 2016                                        | Write            | х               | 2016               |  |
| Erase verify   | Write | Verify address | A016                                        | Read             | Х               | Verify<br>data     |  |
| Reset          | Write | х              | FF16                                        | Write            | Х               | FF16               |  |

#### Read Command (0016)

The read mode is entered by writing the command code "0016" in the first bus cycle. When an address to be read is input in one of the bus cycles that follow, the content of the specified address is read out at the data I/O pins (D0–D7).

The read mode is retained intact until another command is written.

After reset and after the reset command is executed, the read mode is set.

#### **Program Command (4016)**

The program mode is entered by writing the command code "4016" in the first bus cycle. When an address and data to be program is write in the second bus cycle, the flash memory control circuit executes the program operation. The program operation requires approximately 20  $\mu$ s. Wait for 20  $\mu$ s or more before the user go to the next processing.

Note 1: The write operation is not completed immediately by writing a program command once. The user must always execute a program-verify command after each program command executed. And if verification fails, the user need to execute the program command repeatedly until the verification passes. See Figure CC-4 for an example of a programming flowchart.

#### Program-verify command (C016)

The program-verify mode is entered by writing the command code "C016" in the first bus cycle and the verify data is output from the data I/O pins (D0–D7) in the second bus cycle.

#### Erase command (2016 + 2016)

The flash memory control circuit executes an erase operation by writing command code "2016" in the first bus cycle and the same command code again in the second bus cycle. The erase operation requires approximately 20 ms. Wait for 20 ms or more before the user go to the next processing. Before this erase command can be performed, all memory locations to be erased must have had data "0016" written to by using the program and program-verify commands.

Note 1: The erase operation is not completed immediately by writing an erase command once. The user must always execute an erase-verify command after each erase command executed. And if verification fails, the user need to execute the erase command repeatedly until the verification passes. See Figure CC-4 for an example of an erase flowchart.

#### **Erase-verify command (A016)**

The erase-verify mode is entered by writing the command code "A016" in the first bus cycle and the verify data is output from the data I/O pins (D0–D7) in the second bus cycle.

Note 1: If any unerased memory location is encountered during erase-verify operation, be sure to execute erase and erase-verify operations one more time. In this case, however, the user does not need to write data "0016" to memory before erasing.

#### Reset command (FF16 + FF16)

The reset command is used to stop the program command or the erase command in the middle of operation. After writing command code "4016" or "2016" twice, write command code "FF16" in the first bus cycle and the same command code again in the second bus cycle. The program command or erase command is disabled, with the flash memory placed in read mode.



Figure CC-4. Program and erase execution flowchart in the CPU rewrite mode

#### **Protect function**

In parallel I/O mode, the internal flash memory has the "protect function" available. This function protects the flash memory contents from being read or rewritten easily.

Depending on the content at the protect control address (FFFF16) in parallel I/O mode, this function inhibits the flash memory contents against read or modification. The protect control address (FFFF16) is shown in Figure CC-5. (This address exists in the user ROM area.)

The protect function is enabled by setting one of the two protect set bits to "0", so that the internal flash memory contents are inhibited against read or modification. The protect function is disabled by setting both of the two protect reset bits to "00", so that the internal flash memory contents can be read or modified. Once the protect function is set, the user cannot change settings of the protect clear bits while in parallel I/O mode. Settings of the protect reset bits can only be changed in CPU rewrite mode.



Figure CC-5. Protect control address

#### Pin functions (Flash memory standard serial I/O mode)

| Pin        | Name                      | I/O | Description                                                                                     |
|------------|---------------------------|-----|-------------------------------------------------------------------------------------------------|
| Vcc,Vss    | Power input               |     | Apply 5V ± 10 % to Vcc pin and 0 V to Vss pin.                                                  |
| CNVss      | CNVss                     | ı   | Apply 12V ± 5 % to this pin.                                                                    |
| RESET      | Reset input               | I   | Reset input pin. While reset is "L" level, a 20 cycle or longer clock must be input to XIN pin. |
| XIN        | Clock input               | ı   | Connect a ceramic resonator or crystal oscillator between XIN and                               |
| Xout       | Clock output              | 0   | XOUT pins. To input an externally generated clock, input it to XIN pin and open XOUT pin.       |
| AVcc, AVss | Analog power supply input |     | Connect AVss to Vss and AVcc to Vcc, respectively.                                              |
| VREF       | Reference voltage input   | ı   | Enter the reference voltage for AD from this pin.                                               |
| P00 to P07 | Input port P0             | ı   | Input "H" or "L" level signal or open.                                                          |
| P10 to P17 | Input port P1             | I   | Input "H" or "L" level signal or open.                                                          |
| P30 to P35 | Input port P3             | ı   | Input "H" or "L" level signal or open.                                                          |
| P40 to P45 | Input port P4             | I   | Input "H" or "L" level signal or open.                                                          |
| P54        | Input port P5             | I   | Input "H" or "L" level signal or open.                                                          |
| P50        | TxD output                | 0   | Serial data output pin.                                                                         |
| P51        | RxD input                 | ı   | Serial data input pin.                                                                          |
| P52        | SCLK input                | 4   | Serial clock input pin.                                                                         |
| P53        | BUSY output               | 0   | BUSY signal output pin.                                                                         |
| P60 to P67 | Input port P6             |     | Input "H" or "L" level signal or open.                                                          |
| P70 to P71 | Input port P7             | I   | Input "H" or "L" level signal or open.                                                          |





Figure DD-1. Pin connections for serial I/O mode (1)



Figure DD-2. Pin connections for serial I/O mode (2)



#### Standard Serial I/O Mode

The standard serial I/O mode serially inputs and outputs the software commands, addresses and data necessary for operating (read, program, erase, etc.) the internal flash memory. It uses a purpose-specific serial programmer.

The standard serial I/O mode differs from the parallel I/O mode in that the CPU controls operations like rewriting (uses the CPU rewrite mode) in the flash memory or serial input for rewriting data. The standard serial I/O mode is started by clearing the reset with VPPH at the CNVss pin. (For the normal microprocessor mode, set CNVss to "L".)

This control program is written in the boot ROM area when shipped from Mitsubishi Electric. Therefore, if the boot ROM area is rewritten in the parallel I/O mode, the standard serial I/O mode cannot be used. Figures DD-1 and DD-2 show the pin connections for the standard serial I/O mode. Serial data I/O uses three UART0 pins: CLK0, RxD0, and TxD0 and port P53 (BUSY).

The CLKo pin is the transfer clock input pin and it transfers the external transfer clock. The TxDo pin outputs the CMOS signal. The P53 (BUSY) pin outputs an "L" level when reception setup ends and an "H" level when the reception operation starts. Transmission and reception data is transferred serially in 8-byte blocks.

In the standard serial I/O mode, only the user ROM area shown in Figure CC-1 can be rewritten, the boot ROM area cannot.

The standard serial I/O mode has a 7-byte ID code. When the flash memory is not blank and the ID code does not match the content of the flash memory, the command sent from the programmer is not accepted.

#### Function Overview (Standard Serial I/O Mode)

In the standard serial I/O mode, software commands, addresses and data are input and output between the flash memory and an external device (serial programmer, etc.) using a clock synchronized serial I/O (UART0) and P53. In reception, the software commands, addresses and program data are synchronized with the rise of the transfer clock input to the CLK0 pin and input into the flash memory via the RxD0 pin. In transmission, the read data and status are synchronized with the fall of the transfer clock and output to the outside from the TxD0 pin.

The TxD1 pin is CMOS output. Transmission is in 8-bit blocks and LSB first.

When busy, either during transmission or reception, or while executing an erase operation or program, the P53 (BUSY) pin is "H" level. Accordingly, do not start the next transmission until the P53 (BUSY) pin is "L" level.

Also, data in memory and the status register can be read after inputting a software command. It is possible to check flash memory operating status or whether a program or erase operation ended successfully or in error by reading the status register.

Software commands and the status register are explained here following.

#### **Software Commands**

Table DD-1 lists software commands. In the standard serial I/O mode, erase operations, programs and reading are controlled by transferring software commands via the RxD pin. Software commands are explained here below.

Table DD-1. Software commands (Standard serial I/O mode)

|    | Control command              |                  | 2nd byte                  | 3rd byte                  | 4th byte             | 5th byte            | 6th byte                     |                                 | When ID is not verificate |
|----|------------------------------|------------------|---------------------------|---------------------------|----------------------|---------------------|------------------------------|---------------------------------|---------------------------|
| 1  | Page read                    | FF <sub>16</sub> | Address<br>(middle)       | Address<br>(high)         | Data<br>output       | Data<br>output      | Data<br>output               | Data output to 259th            | Not acceptable            |
| 2  | Page program                 | 41 <sub>16</sub> | Address<br>(middle)       | Address<br>(high)         | Data<br>input        | Data<br>input       | Data<br>input                | Data input<br>to 259th<br>byte  | Not<br>acceptable         |
| 3  | Erase all unlocked blocks    | A7 <sub>16</sub> | D0 <sub>16</sub>          |                           |                      |                     |                              | ·                               | Not acceptable            |
| 4  | Read status register         | 70 <sub>16</sub> | SRD<br>output             | SRD1<br>output            |                      |                     |                              |                                 | Acceptable                |
| 5  | Clear status register        | 50 <sub>16</sub> |                           |                           |                      |                     |                              |                                 | Not acceptable            |
| 6  | Read lockbit status          | 71 <sub>16</sub> | Address<br>(middle)       | Address<br>(high)         | Lock bit data output |                     |                              |                                 | Not<br>acceptable         |
| 7  | ID check function            | F5 <sub>16</sub> | Address<br>(low)          | Address<br>(middle)       | Address<br>(high)    | ID size             | ID1                          | To ID7                          | Acceptable                |
| 8  | Download function            | FA <sub>16</sub> | Size<br>(low)             | Size<br>(high)            | Check-<br>sum        | Data<br>input       | To<br>required<br>number     |                                 | Not acceptable            |
| 9  | Version data output function | FB <sub>16</sub> | Version<br>data<br>output | Version<br>data<br>output | Version data output  | Version data output | of times Version data output | Version data output to 9th byte | Acceptable                |
| 14 | Boot area output function    | FC <sub>16</sub> | Address<br>(middle)       | Address<br>(high)         | Data<br>output       | Data<br>output      | Data<br>output               | Data<br>output to<br>259th byte | Not<br>acceptable         |

Note1: Shading indicates transfer from flash memory microcomputer to serial programmer. All other data is transferred from the serial programmer to the flash memory microcomputer.

Note2: SRD refers to status register data. SRD1 refers to status register 1 data.

Note3: All commands can be accepted when the flash memory is totally blank.



#### **Page Read Command**

This command reads the specified page (256 bytes) in the flash memory sequentially one byte at a time. Execute the page read command as explained here following.

- (1) Send the "FF16" command code in the 1st byte of the transmission.
- (2) Send addresses A8 to A15 and A16 to A23 in the 2nd and 3rd bytes of the transmission respectively.
- (3) From the 4th byte onward, data (D0–D7) for the page (256 bytes) specified with addresses A8 to A23 will be output sequentially from the smallest address first in sync with the rise of the clock.



Figure DD-3. Timing for page read

#### Read Status Register Command

This command reads status information. When the "7016" command code is sent in the 1st byte of the transmission, the contents of the status register (SRD) specified in the 2nd byte of the transmission and the contents of status register 1 (SRD1) specified in the 3rd byte of the transmission are read.



Figure DD-4. Timing for reading the status register

#### **Clear Status Register Command**

This command clears the bits (SR3–SR4) which are set when the status register operation ends in error. When the "5016" command code is sent in the 1st byte of the transmission, the aforementioned bits are cleared. When the clear status register operation ends, the P53 (BUSY) signal changes from the "H" to the "L" level.



Figure DD-5. Timing for clearing the status register

#### **Page Program Command**

This command writes the specified page (256 bytes) in the flash memory sequentially one byte at a time. Execute the page program command as explained here following.

- (1) Send the "4116" command code in the 1st byte of the transmission.
- (2) Send addresses A8 to A15 and A16 to A23 in the 2nd and 3rd bytes of the transmission respectively.
- (3) From the 4th byte onward, as write data (D0–D7) for the page (256 bytes) specified with addresses A8 to A23 is input sequentially from the smallest address first, that page is automatically written.

When reception setup for the next 256 bytes ends, the P53 (BUSY) signal changes from the "H" to the "L" level. The result of the page program can be known by reading the status register. For more information, see the section on the status register.



Figure DD-6. Timing for the page program



#### **Erase All Unlocked Blocks Command**

This command erases the content of all blocks. Execute the erase all unlocked blocks command as explained here following.

- (1) Send the "A716" command code in the 1st byte of the transmission.
- (2) Send the verify command code "D016" in the 2nd byte of the transmission. With the verify command code, the erase operation will start and continue for all blocks in the flash memory.

When block erasing ends, the P53 (BUSY) signal changes from the "H" to the "L" level. The result of the erase operation can be known by reading the status register.



Figure DD-7. Timing for erasing all unlocked blocks

#### **Read Lock Bit Status Command**

This command reads the lock bit status of the specified block. Execute the read lock bit status command as explained here following.

- (1) Send the "7116" command code in the 1st byte of the transmission.
- (2) Send addresses A8 to A15 and A16 to A23 in the 2nd and 3rd bytes of the transmission respectively.
- (3) The lock bit data of the specified block is output in the 4th byte of the transmission. Write the highest address of the specified block for addresses A8 to A23.

The M30201 (flash memory version) does not have the lock bit, so the read value is always "1" (block unlock).



Figure DD-8. Timing for reading lock bit status

#### **Download Command**

This command downloads a program to the RAM for execution. Execute the download command as explained here following.

- (1) Send the "FA16" command code in the 1st byte of the transmission.
- (2) Send the program size in the 2nd and 3rd bytes of the transmission.
- (3) Send the check sum in the 4th byte of the transmission. The check sum is added to all data sent in the 5th byte onward.
- (4) The program to execute is sent in the 5th byte onward.

When all data has been transmitted, if the check sum matches, the downloaded program is executed. The size of the program will vary according to the internal RAM.



Figure DD-9. Timing for download

# Under Johnent

#### **Version Information Output Command**

This command outputs the version information of the control program stored in the boot area. Execute the version information output command as explained here following.

- (1) Send the "FB16" command code in the 1st byte of the transmission.
- (2) The version information will be output from the 2nd byte onward. This data is composed of 8 ASCII code characters.



Figure DD-10. Timing for version information output

#### **Boot Area Output Command**

This command outputs the control program stored in the boot area in one page blocks (256 bytes). Execute the boot area output command as explained here following.

- (1) Send the "FC16" command code in the 1st byte of the transmission.
- (2) Send addresses A8 to A15 and A16 to A23 in the 2nd and 3rd bytes of the transmission respectively.
- (3) From the 4th byte onward, data (D0–D7) for the page (256 bytes) specified with addresses A8 to A23 will be output sequentially from the smallest address first, in sync with the rise of the clock.



Figure DD-11. Timing for boot area output

#### **ID Check**

This command checks the ID code. Execute the boot ID check command as explained here following.

- (1) Send the "F516" command code in the 1st byte of the transmission.
- (2) Send addresses A<sub>0</sub> to A<sub>7</sub>, A<sub>8</sub> to A<sub>15</sub> and A<sub>16</sub> to A<sub>23</sub> of the 1st byte of the ID code in the 2nd, 3rd and 4th bytes of the transmission respectively.
- (3) Send the number of data sets of the ID code in the 5th byte.
- (4) The ID code is sent in the 6th byte onward, starting with the 1st byte of the code.



Figure DD-12. Timing for the ID check

#### **ID Code**

When the flash memory is not blank, the ID code sent from the serial programmer and the ID code written in the flash memory are compared to see if they match. If the codes do not match, the command sent from the serial programmer is not accepted. An ID code contains 8 bits of data. Area is, from the 1st byte, addresses 0FFFDF16, 0FFFE316, 0FFFEB16, 0FFFEF16, 0FFFF316, and 0FFFF716. Write a program into the flash memory, which already has the ID code set for these addresses.



Figure DD-13. ID code storage addresses



#### Status Register (SRD)

The status register indicates operating status of the flash memory and status such as whether an erase operation or a program ended successfully or in error. It can be read by writing the read status register command (7016). Also, the status register is cleared by writing the clear status register command (5016). Table DD-2 gives the definition of each status register bit. After clearing the reset, the status register outputs "8016".

Table DD-2. Status register (SRD)

| SRD0 bits  | Status name  | Definition          |                     |  |  |
|------------|--------------|---------------------|---------------------|--|--|
| SINDO DILO | Status fiame | "1"                 | "0"                 |  |  |
| SR7 (bit7) | Status bit   | Ready               | Busy                |  |  |
| SR6 (bit6) | Reserved     |                     | -                   |  |  |
| SR5 (bit5) | Erase bit    | Terminated in error | Terminated normally |  |  |
| SR4 (bit4) | Program bit  | Terminated in error | Terminated normally |  |  |
| SR3 (bit3) | Reserved     |                     | -                   |  |  |
| SR2 (bit2) | Reserved     | -                   | -                   |  |  |
| SR1 (bit1) | Reserved     | -                   | -                   |  |  |
| SR0 (bit0) | Reserved     | -                   | -                   |  |  |

#### Status Bit (SR7)

The status bit indicates the operating status of the flash memory. When power is turned on, "1" (ready) is set for it. The bit is set to "0" (busy) during an auto write or auto erase operation, but it is set back to "1" when the operation ends.

#### Erase Bit (SR5)

The erase bit reports the operating status of the auto erase operation. If an erase error occurs, it is set to "1". When the erase status is cleared, it is set to "0".

#### **Program Bit (SR4)**

The program bit reports the operating status of the auto write operation. If a write error occurs, it is set to "1". When the program status is cleared, it is set to "0".

#### Status Register 1 (SRD1)

Status register 1 indicates the status of serial communications, results from ID checks and results from check sum comparisons. It can be read after the SRD by writing the read status register command (7016). Also, status register 1 is cleared by writing the clear status register command (5016).

Table DD-3 gives the definition of each status register 1 bit. "0016" is output when power is turned ON and the flag status is maintained even after the reset.

Table DD-3. Status register 1 (SRD1)

| SRD1 bits Status name |                           | De               | finition                  |
|-----------------------|---------------------------|------------------|---------------------------|
| SKUT DITS             | Status name               | "1"              | "0"                       |
| SR15 (bit7)           | Boot update completed bit | Update completed | Not update                |
| SR14 (bit6)           | Reserved                  | -                |                           |
| SR13 (bit5)           | Reserved                  | -                |                           |
| SR12 (bit4)           | Checksum match bit        | Match            | Mismatch                  |
| SR11 (bit3)           | ID check completed bits   |                  | verified                  |
| SR10 (bit2)           |                           |                  | ication mismatch<br>erved |
|                       |                           | 11 Verif         |                           |
| SR9 (bit1)            | Data receive time out     | Time out         | Normal operation          |
| SR8 (bit0)            | Reserved                  | -                | -                         |

#### **Boot Update Completed Bit (SR15)**

This flag indicates whether the control program was downloaded to the RAM or not, using the download function.

#### **Check Sum Consistency Bit (SR12)**

This flag indicates whether the check sum matches or not when a program, is downloaded for execution using the download function.

#### ID Check Completed Bits (SR11 and SR10)

These flags indicate the result of ID checks. Some commands cannot be accepted without an ID check.

#### **Data Reception Time Out (SR9)**

This flag indicates when a time out error is generated during data reception. If this flag is attached during data reception, the received data is discarded and the microcomputer returns to the command wait state.

#### **Example Circuit Application for The Standard Serial I/O Mode**

The below figure shows a circuit application for the standard serial I/O mode. Control pins will vary according to programmer, therefore see the programmer manual for more information.



Figure DD-14. Example circuit application for the standard serial I/O mode

52P4B Plastic 52pin 600mil SDIP





#### Plastic 56pin 10×10mm body QFP



## Chapter 2

Peripheral Functions Usage

#### 2.1 Protect

#### 2.1.1 Overview

'Protect' is a function that causes a value held in a register to be unchanged even when a program runs away. The following is an overview of the protect function:

#### (1) Registers affected by the protect function

The registers affected by the protect function are:

- (a) System clock control registers 0, 1 (addresses 000616 and 000716)
- (b) Processor mode registers 0, 1 (addresses 000416 and 000516)
- (c) Port P4 direction register (address 03EA<sub>16</sub>)

The values in registers (1) through (3) cannot be changed in write-protect state. To change values in the registers, put the individual registers in write-enabled state.

#### (2) Protect register

Figure 2.1.1 shows protect register.



Figure 2.1.1. Protect register

#### 2.1.2 Protect Operation

The following explains the protect operation. Figure 2.1.2 shows the set-up procedure.

Operation (1) Setting "1" in the write-enable bit of system clock control registers 0 and 1 causes system clock control register 1 to be in write-enabled state.

- (2) The contents of system clock control register 0 and that of system clock control register 1 are changed.
- (3) Setting "0" in the write-enable bit of system control registers 0 and 1 causes system clock control register 0 and system control register 1 to be in write-inhibited state.
- (4) To change the contents of processor mode register 0 and that of processor mode register 1, follow the same steps as in dealing with system clock control registers.
- (5) The write-enable bit of port P4 direction register goes to "0" when the next write instruction is executed after write-enabled state is readied. Make changes in input/output immediately after the instruction that sets "1" in the write-enable bit of port P4 direction register (avoid causing an interrupt).



Figure 2.1.2. Set-up procedure for protect function

#### 2.1.3 Precaution for Protect

(1) The write-enable bit of port P4 direction register goes to "0" when the next write instruction is executed after write-enabled state is readied. Make changes in input/output immediately after the instruction that sets "1" in the write-enable bit of port P4 direction register (avoid causing an interrupt).

#### Timer A

#### 2.2 Timer A

#### 2.2.1 Overview

The following is an overview for timer A, a 16-bit timer.

#### (1) Mode

Timer A operates in one of the four modes:

#### (a) Timer mode

In this mode, the internal count source is counted. Two functions can be selected: the pulse output function that reverses output from a port every time an overflow occurs, or the gate function which controls the count start/stop according to the input signal from a port.

| Timer mode operation                        | P168 |
|---------------------------------------------|------|
| Timer mode, gate function operation         | P170 |
| Timer mode, pulse output function operation | P172 |

#### (b) Event counter mode

This mode counts the pulses from the outside and the number of overflows in other timers. The freerun type, in which nothing is reloaded from the reload register, can be selected when an underflow occurs. The pulse output function can also be selected. Please refer to the timer mode explanation for details, as the operation is identical.

| • Event counter mode operation                | 174 |
|-----------------------------------------------|-----|
| • Event counter mode, free run type operation | 176 |

Furthermore, Timer A has a 2-phase pulse signal processing function which generates an up count

- or down count in the event counter mode, depending on the phase of the two input signals.

   Operation of the 2-phase pulse signal processing function in normal event counter mode ..... P178

#### (c) One-shot timer mode

In this mode, the timer is started by the trigger and stops when the timer goes to "0". The trigger can be selected from the following 3 types: an external input signal, an overflow of the timer, or a software trigger. The pulse output function can also be selected. Please refer to the timer mode explanation for details, as the operation is identical.

- Operation in one-shot timer mode effected by an external trigger ...... P184

#### (d) Pulse width modulation (PWM) mode

In this mode, the arbitrary pulses are successively output. Either a 16-bit fixed-period PWM mode or 8-bit variable-period mode can be selected. The trigger for initiating output can also be selected. Please refer to the one-shot timer mode explanation for details, as the operation is identical.



#### (2) Count source

The internal count source can be selected from f1, f8, f32, and fC32. Clocks f1, f8, and f32 are derived by dividing the CPU's main clock by 1, 8, and 32 respectively. Clock fC32 is derived by dividing the CPU's secondary clock by 32.

#### (3) Frequency division ratio

In timer mode or pulse width modulation mode, [the value set in the timer register + 1] becomes the frequency division ratio. In event counter mode, [the set value + 1] becomes the frequency division ratio when a down count is performed, or [FFFF16 - the set value + 1] becomes the frequency division ratio when an up count is performed. In one-shot timer mode, the value set in the timer register becomes the frequency division ratio.

The counter overflows (or underflows) when a count source equal to a frequency division ratio is input, and an interrupt occurs. For the pulse output function, the output from the port varies (the value in the port register does not vary).

#### (4) Reading the timer

Either in timer mode or in event counter mode, reading the timer register takes out the count at that moment. Read it in 16-bit units. The data either in one-shot timer mode or in pulse width modulation mode is indeterminate.

#### (5) Writing to the timer

To write to the timer register when a count is in progress, the value is written only to the reload register. When writing to the timer register when a count is stopped, the value is written both to the reload register and to the counter. Write a value in 16-bit units.

#### (6) Relation between the input/output to/from the timer and the direction register

With the output function of the timer, set the direction register of the relevant port to input. To input an external signal to the timer, set the direction register of the relevant port to input.

#### (7) Pins related to timer A

(a) TA0IN Input pins to timer A.

(b) TA00UT Output pins from timer A. They become input pins to timer A when event counter

mode is active.

#### (8) Registers related to timer A

Figure 2.2.1 shows the memory map of timer A-related registers. Figures 2.2.2 through 2.2.5 show timer A-related registers.



Figure 2.2.1. Memory map of timer A-related registers



Figure 2.2.2. Timer A-related registers (1)





Figure 2.2.3. Timer A-related registers (2)

#### Timer A



Figure 2.2.4. Timer A-related registers (3)



Figure 2.2.5. Timer A-related registers (4)



## 2.2.2 Operation of Timer A (timer mode)

In timer mode, choose functions from those listed in Table 2.2.1. Operations of the circled items are described below. Figure 2.2.6 shows the operation timing, and Figure 2.2.7 shows the set-up procedure.

Table 2.2.1. Choosed functions

| Item                  |   | Set-up                                                                    |  |  |
|-----------------------|---|---------------------------------------------------------------------------|--|--|
| Count source          | 0 | Internal count source (f1 / f8 / f32 / fc32)                              |  |  |
| Pulse output function | 0 | No pulses output                                                          |  |  |
|                       |   | Pulses output                                                             |  |  |
| Gate function         | 0 | No gate function                                                          |  |  |
|                       |   | Performs count only for the period in which the TA0IN pin is at "L" level |  |  |
|                       |   | Performs count only for the period in which the TA0IN pin is at "H" level |  |  |

- Operation (1) Setting the count start flag to "1" causes the counter to perform a down count on the count source.
  - (2) If an underflow occurs, the content of the reload register is reloaded, and the count continues. At this time, the timer A0 interrupt request bit goes to "1".
  - (3) Setting the count start flag to "0" causes the counter to hold its value and to stop.



Figure 2.2.6. Operation timing of timer mode





Figure 2.2.7. Set-up procedure of timer mode



## 2.2.3 Operation of Timer A (timer mode, gate function selected)

In timer mode, choose functions from those listed in Table 2.2.2. Operations of the circled items are described below. Figure 2.2.8 shows the operation timing, and Figure 2.2.9 shows the set-up procedure.

Table 2.2.2. Choosed functions

| Item                  |   | Set-up                                                                    |  |  |  |
|-----------------------|---|---------------------------------------------------------------------------|--|--|--|
| Count source          | 0 | Internal count source(f1 / f8 / f32 / fc32)                               |  |  |  |
| Pulse output function | 0 | No pulses output                                                          |  |  |  |
|                       |   | Pulses output                                                             |  |  |  |
| Gate function         |   | No gate function                                                          |  |  |  |
|                       |   | Performs count only for the period in which the TA0IN pin is at "L" level |  |  |  |
|                       | 0 | Performs count only for the period in which the TA0IN pin is at "H" level |  |  |  |

Operation (1) When the count start flag is set to "1" and the TA0IN pin inputs at "H" level, the counter performs a down count on the count source.

- (2) When the TA0IN pin inputs at "L" level, the counter holds its value and stops.
- (3) If an underflow occurs, the content of the reload register is reloaded and the count continues. At this time, the timer A0 interrupt request bit goes to "1".
- (4) Setting the count start flag to "0" causes the counter to hold its value and to stop.

Note

 Make the pulse width of the signal input to the TA0IN pin not less than two cycles of the count source.



Figure 2.2.8. Operation timing of timer mode, gate function selected



Figure 2.2.9. Set-up procedure of timer mode, gate function selected



## 2.2.4 Operation of Timer A (timer mode, pulse output function selected)

In timer mode, choose functions from those listed in Table 2.2.3. Operations of the circled items are described below. Figure 2.2.10 shows the operation timing, and Figure 2.2.11 shows the set-up procedure.

Table 2.2.3. Choosed functions

| Item                  |   | Set-up                                                                    |  |  |
|-----------------------|---|---------------------------------------------------------------------------|--|--|
| Count source          | 0 | Internal count source(f1 / f8 / f32 / fc32)                               |  |  |
| Pulse output function |   | No pulses output                                                          |  |  |
|                       | 0 | Pulses output                                                             |  |  |
| Gate function         | 0 | No gate function                                                          |  |  |
|                       |   | Performs count only for the period in which the TA0IN pin is at "L" level |  |  |
|                       |   | Performs count only for the period in which the TA0IN pin is at "H" level |  |  |

- Operation (1) Setting the count start flag to "1" causes the counter to perform a down count on the count source.
  - (2) If an underflow occurs, the content of the reload register is reloaded and the count continues. At this time, the timer A0 interrupt request bit goes to "1". Also, the output polarity of the TA0out pin reverses.
  - (3) Setting the count start flag to "0" causes the counter to hold its value and to stop. Also, the TA0out pin outputs an "L" level.



Figure 2.2.10. Operation timing of timer mode, pulse output function selected





Figure 2.2.11. Set-up procedure of timer mode, pulse output function selected



## 2.2.5 Operation of Timer A (event counter mode, reload type selected)

In event counter mode, choose functions from those listed in Table 2.2.4. Operations of the circled items are described below. Figure 2.2.12 shows the operation timing, and Figure 2.2.13 shows the set-up procedure.

Table 2.2.4. Choosed functions

| Item         | Set-up |                                                                                      | Item                                     | Set-up |                         |
|--------------|--------|--------------------------------------------------------------------------------------|------------------------------------------|--------|-------------------------|
| Count source | О      | Input signal to TA0เห<br>(counting falling edges)                                    | Pulse output function                    |        | No pulses output        |
|              |        |                                                                                      |                                          |        | Pulses output           |
|              |        | Input signal to TA0IN (counting rising edges)  Timer overflow (TB1/TX0/TX2 overflow) | Count operation type                     | 0      | Reload type             |
|              |        |                                                                                      |                                          |        | Free-run type           |
|              |        |                                                                                      | Factor for switching between up and down | 0      | Content of up/down flag |
|              |        |                                                                                      |                                          |        | Input signal to TA0оuт  |
|              |        |                                                                                      |                                          |        |                         |

- Operation (1) Setting the count start flag to "1" causes the counter to count the falling edges of the count source.
  - (2) If an underflow occurs, the content of the reload register is reloaded, and the count continues. At this time, the timer A0 interrupt request bit goes to "1".
  - (3) If switching from an up count to a down count or vice versa while a count is in progress, the switch takes effect from the next effective edge of the count source.
  - (4) Setting the count start flag to "0" causes the counter to hold its value and to stop.
  - (5) If an overflow occurs, the content of the reload register is reloaded, and the count continues. At this time, the timer A0 interrupt request bit goes to "1".



Figure 2.2.12. Operation timing of event counter mode, reload type selected





Figure 2.2.13. Set-up procedure of event counter mode, reload type selected



## 2.2.6 Operation of Timer A (event counter mode, free run type selected)

In event counter mode, choose functions from those listed in Table 2.2.5. Operations of the circled items are described below. Figure 2.2.14 shows the operation timing, and Figure 2.2.15 shows the set-up procedure.

Table 2.2.5. Choosed functions

| Item         | Set-up |                                                                                      | Item                                     | Set-up |                         |
|--------------|--------|--------------------------------------------------------------------------------------|------------------------------------------|--------|-------------------------|
| Count source | О      | O Input signal to TA0IN (counting falling edges)                                     | Pulse output function                    | 0      | No pulses output        |
|              |        |                                                                                      |                                          |        | Pulses output           |
|              |        | Input signal to TA0IN (counting rising edges)  Timer overflow (TB1/TX0/TX2 overflow) | Count operation type                     |        | Reload type             |
|              |        |                                                                                      |                                          | 0      | Free-run type           |
|              |        |                                                                                      | Factor for switching between up and down | 0      | Content of up/down flag |
|              |        |                                                                                      |                                          |        | Input signal to TA0оuт  |
|              |        |                                                                                      |                                          |        |                         |

Operation (1) Setting the count start flag to "1" causes the counter to count the falling edges of the count source.

- (2) Even if an underflow occurs, the content of the reload register is not reloaded, but the count continues. At this time, the timer A0 interrupt request bit goes to "1".
- (3) If switching from an up count to a down count or vice versa while a count is in progress, the switch takes effect from the next effective edge of the count source.
- (4) Even if an overflow occurs, the content of the reload register is not reloaded, but the count continues. At this time, the timer A0 interrupt request bit goes to "1".



Figure 2.2.14. Operation timing of event counter mode, free run type selected





Figure 2.2.15. Set-up procedure of event counter mode, free run type selected

# 2.2.7 Operation of timer A (2-phase pulse signal process in event counter mode, normal mode selected)

In processing 2-phase pulse signals in event counter mode, choose functions from those listed in Table 2.2.6. Operations of the circled items are described below. Figure 2.2.16 shows the operation timing, and Figure 2.2.17 shows the set-up procedure.

Table 2.2.6. Choosed functions

| Item                 |   | Set-up                      |
|----------------------|---|-----------------------------|
| Count operation type |   | Reload type                 |
|                      | 0 | Free run type               |
| 2-phase pulses       | 0 | Normal processing           |
| process              |   | 4-multiplication processing |

Operation (1) Setting the count start flag to "1" causes the counter to count effective edges of the count source.

- (2) Even if an underflow occurs, the content of the reload register is not reloaded, but the count continues. At this time, the timer A0 interrupt request bit goes to "1".
- (3) Even if an overflow occurs, the content of the reload register is not reloaded, but the count continues. At this time, the timer A0 interrupt request bit goes to "1".

Note • The up count or down count conditions are as follows:

If a rising edge is present at the TA0IN pin when the input signal level to the TA0OUT pin is "H", an up count is performed.

If a falling edge is present at the TA0IN pin when the input signal level to the TA0OUT pin is "H", a down count is performed.



Figure 2.2.16. Operation timing of 2-phase pulse signal process in event counter mode, normal mode selected



Figure 2.2.17. Set-up procedure of 2-phase pulse signal process in event counter mode, normal mode selected

# 2.2.8 Operation of timer A (2-phase pulse signal process in event counter mode, multiply-by-4 mode selected)

In processing 2-phase pulse signals in event counter mode, choose functions from those listed in Table 2.2.7. Operations of the circled items are described below. Figure 2.2.18 shows the operation timing, and Figure 2.2.19 shows the set-up procedure.

Table 2.2.7. Choosed functions

| Item                 | Set-up |               | Item               | Set-up |                             |
|----------------------|--------|---------------|--------------------|--------|-----------------------------|
| Count operation type |        | Reload type   | Processing 2 phase |        | Normal processing           |
|                      | 0      | Free run type | pulses             | 0      | 4-multiplication processing |

Operation (1) Setting the count start flag to "1" causes the counter to count effective edges of the count source.

- (2) Even if an underflow occurs, the content of the reload register is not reloaded, but the count continues. At this time, the timer A0 interrupt request bit goes to "1".
- (3) Even if an overflow occurs, the content of the reload register is not reloaded, but the count continues. At this time, the timer A0 interrupt request bit goes to "1".

Note The up count or down count conditions are as follows:

Table 2.2.8. The up count or down count conditions

|          | Input signal to the TA0ou⊤ pin | Input signal to the<br>TA0เท pin |       | Input signal to the<br>TA0o∪⊤ pin | Input signal to the TA0IN pin |
|----------|--------------------------------|----------------------------------|-------|-----------------------------------|-------------------------------|
| Up count | "H" level                      | Rising                           | Down  | "H" level                         | Falling                       |
|          | "L" level                      | Falling                          | count | "L" level                         | Rising                        |
|          | Rising                         | "L" level                        |       | Rising                            | "H" level                     |
|          | Falling                        | "H" level                        |       | Falling                           | "L" level                     |



Figure 2.2.18. Operation timing of 2-phase pulse signal process in event counter mode, multiply-by-4 mode selected



Figure 2.2.19. Set-up procedure of2-phase pulse signal process in event counter mode, multiply-by-4 mode selected



## 2.2.9 Operation of Timer A (one-shot timer mode)

In one-shot timer mode, choose functions from those listed in Table 2.2.9. Operations of the circled items are described below. Figure 2.2.20 shows the operation timing, and Figure 2.2.21 shows the set-up procedure.

Table 2.2.9. Choosed functions

| Item                  |   | Set-up                                                                 |  |  |
|-----------------------|---|------------------------------------------------------------------------|--|--|
| Count source          | 0 | Internal count source (f1 / f8 / f32 / fc32)                           |  |  |
| Pulse output function |   | No pulses output                                                       |  |  |
|                       | 0 | Pulses output                                                          |  |  |
| Count start condition |   | External trigger input (falling edge of input signal to the TA0IN pin) |  |  |
|                       |   | External trigger input (rising edge of input signal to the TA0IN pin)  |  |  |
|                       |   | Timer overflow (TB1/TX0/TX2 overflow)                                  |  |  |
|                       | 0 | Writing "1" to the one-shot start flag                                 |  |  |

Operation (1) Setting the one-shot start flag to "1" with the count start flag set to "1" causes the counter to perform a down count on the count source. At this time, the TA0out pin outputs an "H" level.

- (2) The instant the value of the counter becomes "000016", the TA00UT pin outputs an "L" level, and the counter reloads the content of the reload register and stops counting. At this time, the timer A0 interrupt request bit goes to "1".
- (3) If a trigger occurs while a count is in progress, the counter reloads the value in the reload register again and continues counting. The reload timing is in step with the next count source input after the trigger.
- (4) Setting the count start flag to "0" causes the counter to stop and to reload the content of the reload register. Also, the TA0out pin outputs an "L" level. At this time, the timer A0 interrupt request bit goes to "1".



Figure 2.2.20. Operation timing of one-shot mode



Figure 2.2.21. Set-up procedure of one-shot mode



## 2.2.10 Operation of Timer A (one-shot timer mode, external trigger selected)

In one-shot timer mode, choose functions from those listed in Table 2.2.10. Operations of the circled items are described below. Figure 2.2.22 shows the operation timing, and Figure 2.2.23 shows the set-up procedure.

Table 2.2.10. Choosed functions

| Item                  |   | Set-up                                                                 |
|-----------------------|---|------------------------------------------------------------------------|
| Count source          | 0 | Internal count source (f1 / f8 / f32 / fc32)                           |
| Pulse output function |   | No pulses output                                                       |
|                       | 0 | Pulses output                                                          |
| Count start condition |   | External trigger input (falling edge of input signal to the TA0IN pin) |
|                       | 0 | External trigger input (rising edge of input signal to the TA0IN pin)  |
|                       |   | Timer overflow (TB1/TX0/TX2 overflow)                                  |
|                       |   | Writing "1" to the one-shot start flag                                 |

- Operation (1) If the TA0IN pin input level changes from "L" to "H" with the count start flag set to "1", the counter performs a down count on the count source. At this time, the TA0OUT pin output level goes to "H" level.
  - (2) If the value of the counter becomes "000016", the TA00UT pin outputs an "L" level, and the counter reloads the content of the reload register and stops counting. At this time, the timer A0 interrupt request bit goes to "1".
  - (3) If a trigger occurs while a count is in progress, the counter reloads the value of the reload register again and continues counting. The reload timing is in step with the next count source input after the trigger.
  - (4) Setting the count start flag to "0" causes the counter to stop and to reload the content of the reload register. Also, the TA0out pin outputs an "L" level. At this time, the timer A0 interrupt request bit goes to "1".



Figure 2.2.22. Operation timing of one-shot mode, external trigger selected





Figure 2.2.23. Set-up procedure of one-shot mode, external trigger selected



## 2.2.11 Operation of Timer A (pulse width modulation mode, 16-bit PWM mode selected)

In pulse width modulation mode, choose functions from those listed in Table 2.2.11. Operations of the circled items are described below. Figure 2.2.24 shows the operation timing, and Figure 2.2.25 shows the set-up procedure.

Table 2.2.11. Choosed functions

|                       |   | ***************************************                                |  |  |
|-----------------------|---|------------------------------------------------------------------------|--|--|
| Item                  |   | Set-up                                                                 |  |  |
| Count source          | 0 | Internal count source (f1 / f8 / f32 / fc32)                           |  |  |
| PWM mode              | 0 | 16-bit PWM                                                             |  |  |
|                       |   | 8-bit PWM                                                              |  |  |
| Count start condition |   | External trigger input (falling edge of input signal to the TA0IN pin) |  |  |
|                       | 0 | External trigger input (rising edge of input signal to the TA0IN pin)  |  |  |
|                       |   | Timer overflow (TB1/TX0/TX2 overflow)                                  |  |  |

Operation (1) If the TA0IN pin input level changes from "L" to "H" with the count start flag set to "1", the counter performs a down count on the count source. Also, the TA0OUT pin outputs an "H" level.

- (2) The TA0out pin output level changes from "H" to "L" when a set time period elapses. At this time, the timer A0 interrupt request bit goes to "1".
- (3) The counter reloads the content of the reload register every time PWM pulses are output for one cycle, and continues counting.
- (4) Setting the count start flag to "0" causes the counter to hold its value and to stop. Also, the TA0out outputs an "L" level.

Note

PWM pulse cycle is (2<sup>16</sup> -1)/fi, whereas H level duration is n/fi. However, when "000016" is set for the timer A0 register, the PWM output is "L" level for the entire period, and an interrupt request is generated for every PWM output cycle. Also, when "FFFF16" is set for the timer A0 register, the PWM output is "H" level for the entire period, and an interrupt request is generated for every PWM output cycle.

(fi: Count source frequency f1, f8, f32, fC32 n: Timer value)



Figure 2.2.24. Operation timing of pulse width modulation mode, 16-bit PWM mode selected





Figure 2.2.25. Set-up procedure of pulse width modulation mode, 16-bit PWM mode selected



## 2.2.12 Operation of Timer A (pulse width modulation mode, 8-bit PWM mode selected)

In pulse width modulation mode, choose functions from those listed in Table 2.2.12. Operations of the circled items are described below. Figure 2.2.26 shows the operation timing, and Figure 2.2.27 shows the set-up procedure.

Table 2.2.12. Choosed functions

| Item                  |   | Set-up                                                                 |  |  |
|-----------------------|---|------------------------------------------------------------------------|--|--|
| Count source          | 0 | Internal count source (f1 / f8 / f32 / fc32)                           |  |  |
| PWM mode              |   | 16-bit PWM                                                             |  |  |
|                       | 0 | 8-bit PWM                                                              |  |  |
| Count start condition | 0 | External trigger input (falling edge of input signal to the TA0IN pin) |  |  |
|                       |   | External trigger input (rising edge of input signal to the TA0IN pin)  |  |  |
|                       |   | Timer overflow (TB1/TX0/TX2 overflow)                                  |  |  |

Operation (1) If the TA0IN pin input level changes from "H" to "L" with the count start flag set to "1", the counter performs a down count on the count source. Also, the TA00UT pin outputs an "H" level.

- (2) The TA0out pin output level changes from "H" to "L" when a set time period elapses. At this time, the timer A0 interrupt request bit goes to "1".
- (3) The counter reloads the content of the reload register every time PWM pulses are output for one cycle, and continues counting.
- (4) Setting the count start flag to "0" causes the counter to hold its value and to stop. Also, the TA0out pin outputs an "L" level.

Note

• PWM pulse cycle is (m + 1( x (2<sup>8</sup> -1)/fi, whereas "H" level duration is n x (m + 1)/fi. However, when "0016" is set for the significant 8 bits of the timer A0 register, the PWM output is "L" level for the entire period, and an interrupt request is generated for every PWM output cycle. Also, when "FF16" is set for the significant 8 bits of the timer A0 register, the PWM output is "H" level for the entire period, and an interrupt request is generated for every PWM output cycle. (fi: Count source frequency f1, f8, f32, fC32 n: Timer value)



Figure 2.2.26. Operation timing of pulse width modulation mode, with 8-bit PWM mode selected





Figure 2.2.27. Set-up procedure of pulse width modulation mode, 8-bit PWM mode selected

## 2.2.13 Precautions for Timer A (timer mode)

- (1) To clear reset, the count start flag is set to "0". Set a value in the timer A0 register, then set the flag to "1".
- (2) Reading the timer A0 register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the timer A0 register with the reload timing shown in Figure 2.2.28 gets "FFFF16". Reading the timer A0 register after setting a value in the timer A0 register with a count halted but before the counter starts counting gets a proper value.



Figure 2.2.28. Reading timer A0 register

## 2.2.14 Precautions for Timer A (event counter mode)

- (1) To clear reset, the count start flag is set to "0". Set a value in the timer A0 register, then set the flag to "1".
- (2) Reading the timer A0 register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the timer A0 register with the reload timing shown in Figure 2.2.29 gets "FFFF16" by underflow or "000016" by overflow. Reading the timer A0 register after setting a value in the timer A0 register with a count halted but before the counter starts counting gets a proper value.
- (3) Please note the standards for the differences between the 2 pulses used in the 2-phase pulse signals input signals to the TA0IN pin and TA0OUT pin as shown in Figure 2.2.30.
- (4) When free run type is selected, if count is stopped, set a value in the timer A0 register again.



Figure 2.2.29. Reading timer A0 register



Figure 2.2.30. Standard of 2-phase pulses



## 2.2.15 Precautions for Timer A (one-shot timer mode)

- (1) To clear reset, the count start flag is set to "0". Set a value in the timer A0 register, then set the flag to "1".
- (2) Setting the count start flag to "0" while a count is in progress causes as follows:
  - The counter stops counting and a content of reload register is reloaded.
  - The TA0out pin outputs "L" level.
  - The interrupt request generated and the timer A0 interrupt request bit goes to "1".
- (3) The output from the one-shot timer synchronizes with the count source generated internally. Therefore, when an external trigger has been selected, a delay of one cycle of the maximum count source occurs between the trigger input to the TAOIN pin and the one-shot timer output.
- (4) The timer A0 interrupt request bit goes to "1" if the timer's operation mode is set using any of the following procedures:
  - Selecting one-shot timer mode after reset.
  - Changing operation mode from timer mode to one-shot timer mode.
  - Changing operation mode from event counter mode to one-shot timer mode.

Therefore, to use timer A0 interrupt (interrupt request bit), set timer A0 interrupt request bit to "0" after the above listed changes have been made.

(5) If a trigger occurs while a count is in progress, after the counter performs one down count following the reoccurrence of a trigger, the reload register contents are reloaded, and the count continues. To generate a trigger while a count is in progress, generate the second trigger after an elapse longer than one cycle of the timer's count source after the previous trigger occurred.



Figure 2.2.31. One-shot timer delay



## 2.2.16 Precautions for Timer A (pulse width modulation mode)

- (1) To clear reset, the count start flag is set to "0". Set a value in the timer A0 register, then set the flag to "1".
- (2) The timer A0 interrupt request bit becomes "1" if setting operation mode of the timer in compliance with any of the following procedures:
  - Selecting PWM mode after reset.
  - Changing operation mode from timer mode to PWM mode.
  - Changing operation mode from event counter mode to PWM mode.

Therefore, to use timer A0 interrupt (interrupt request bit), set timer A0 interrupt request bit to "0" after the above listed changes have been made.

- (3) Setting the count start flag to "0" while PWM pulses are being output causes the counter to stop counting. If the TA0out pin is outputting an "H" level in this instance, the output level goes to "L", and the timer A0 interrupt request bit goes to "1". If the TA0out pin is outputting an "L" level in this instance, the level does not change, and the timer A0 interrupt request bit does not becomes "1".
- (4) Normal PWM output is restored according to the interrupt request generate timing, both in the case of 16-bit PWM and 8-bit PWM, when PWM output is either "H" or "L" level for the entire period. This holds only when a value other than "000016" or "FFFF16" is set during 16-bit PWM, or a value other than "0016" or "FF16" is set during 8-bit PWM.



Figure 2.2.32. Operation timing of PWM output mode



#### 2.3 Timer B

#### 2.3.1 Overview

The following is an overview for timer B, a 16-bit timer.

#### (1) Mode

Timer B operates in one of three modes:

#### (a) Timer mode

The internal count source is counted.

#### (b) Event counter mode

The number of pulses coming from outside and the number of the timer overflows are counted.

#### (c) Pulse period measurement/pulse width measurement mode

External pulse period or external pulse widths are measured. If pulse period measurement mode is selected, the periods of input pulses are continuously measured. If pulse width measurement mode is selected, widths of "H" level pulses and those of "L" level pulses are continuously measured.

#### (2) Count source

An internal count source can be selected from f1, f8, f32, and fC32. f1, f8, and f32 are clocks obtained by dividing the CPU main clock by 1, 8, and 32 respectively. fC32 is the clock obtained by dividing the CPU secondary clock by 32.

#### (3) Frequency division ratio

The frequency division ratio equals [the value set in the timer register + 1]. The counter underflows when a count source equal to a frequency division ratio is input, and an interrupt request occurs.

#### (4) Reading the timer

In timer mode or event counter mode, the count value at the time of reading the timer register will be read. Read the register in 16-bit increments. In both the pulse period measurement mode and pulse width measurement mode, an indeterminate value is read until the second effective edge is input after a count is started, otherwise, the measurement results are read.

#### (5) Writing to the timer

When writing to the timer register while a count is in progress, the value is written only to the reload register. When writing to the timer register while a count has stopped, the value is written both to the reload register and the count. Write the value in 16-bit increments. The timer register cannot be written to in either the pulse period measurement mode or the pulse width measurement mode.

#### (6) Input to the timer and the direction register

To input an external signal to the timer, set the direction register of the relevant port to input.

#### (7) Pins related to timer B

(a) TB0IN, TB1IN Input pins to timer B.

### (8) Registers related to timer B

Figure 2.3.1 shows the memory map of timer B-related registers. Figures 2.3.2 and 2.3.3 show timer B-related registers.



Figure 2.3.1. Memory map of timer B-related registers



Figure 2.3.2. Timer B-related registers (1)



Figure 2.3.3. Timer B-related registers (2)

## 2.3.2 Operation of Timer B (timer mode)

In timer mode, choose functions from those listed in Table 2.3.1. Operations of the circled items are described below. Figure 2.3.4 shows the operation timing, and Figure 2.3.5 shows the set-up procedure.

Table 2.3.1. Choosed functions

| Item         | Set-up |                                              |
|--------------|--------|----------------------------------------------|
| Count source | 0      | Internal count source (f1 / f8 / f32 / fc32) |

Operation (1) Setting the count start flag to "1" causes the counter to perform a down count on the count source.

- (2) If an underflow occurs, the content of the reload register is reloaded, and the counter continues counting. At this time, the timer Bi interrupt request bit goes to "1".
- (3) Setting the count start flag to "0" causes the counter to hold its value and to stop.



Figure 2.3.4. Operation timing of timer mode

## Timer B



Figure 2.3.5. Set-up procedure of timer mode

## Timer B

## 2.3.3 Operation of Timer B (event counter mode)

In event counter mode, choose functions from those listed in Table 2.3.2. Operations of the circled items are described below. Figure 2.3.6 shows the operation timing, and Figure 2.3.7 shows the set-up procedure.

Table 2.3.2. Choosed functions

| Item         |   | Set-up                                                                 |
|--------------|---|------------------------------------------------------------------------|
| Count source | 0 | Input signal to the TBiln pin (counting falling edges)                 |
|              |   | Input signal to the TBilN pin (counting rising edges)                  |
|              |   | Input signal to the TBin pin (counting rising edges and falling edges) |
|              |   | Timer overflow(TBj overflow)                                           |

- Operation (1) Setting the count start flag to "1" causes the counter to count the falling edges of the count source.
  - (2) If an underflow occurs, the content of the reload register is reloaded, and the count continues. At this time, the timer Bi interrupt request bit goes to "1".
  - (3) Setting the count start flag to "0" causes the counter to hold its value and to stop.



Figure 2.3.6. Operation timing of event counter mode



Figure 2.3.7. Set-up procedure of event counter mode

## 2.3.4 Operation of Timer B (pulse period measurement mode)

In pulse period/pulse width measurement mode, choose functions from those listed in Table 2.3.3. Operations of the circled items are described below. Figure 2.3.8 shows the operation timing, and Figure 2.3.9 shows the set-up procedure.

Table 2.3.3. Choosed functions

| Item         | Set-up |                                                                                                                                   |  |
|--------------|--------|-----------------------------------------------------------------------------------------------------------------------------------|--|
| Count source | 0      | Internal count source (f1 / f8 / f32 / fc32)                                                                                      |  |
| Measurement  | 0      | Pulse period measurement (interval between measurement pulse falling edge to falling edge)                                        |  |
| mode         |        | Pulse period measurement (interval between measurement pulse rising edge to rising edge)                                          |  |
|              |        | Pulse width measurement (interval between measurement pulse falling edge to rising edge, and between rising edge to falling edge) |  |

Operation (1) Setting the count start flag to "1" causes the counter to start counting the count source.

- (2) If a measurement pulse changes from "H" to "L", the value of the counter goes to "000016", and measurement is started. In this instance, an indeterminate value is transferred to the reload register. The timer Bi interrupt request does not generate.
- (3) If a measurement pulse changes from "H" to "L" again, the value of the counter is transferred to the reload register, and the timer Bi interrupt request bit goes to "1". Then the value of the counter becomes "000016", and the measurement is started again.

Note

- The timer Bi interrupt request bit goes to "1" when an effective edge of a measurement pulse is input or timer Bi is overflowed. The factor of interrupt request can be determined by use of the timer Bi overflow flag within the interrupt routine.
- The value of the counter at the beginning of a count is indeterminate. Thus there can be instances in which the timer Bi overflow flag goes to "1" immediately after a count is performed.
- The timer Bi overflow flag goes to "0" if timer Bi mode register is written to when the count start flag is "1". This flag cannot be set to "1" by software.



Figure 2.3.8. Operation timing of pulse period measurement mode





Figure 2.3.9. Set-up procedure of pulse period measurement mode

## 2.3.5 Operation of Timer B (pulse width measurement mode)

In pulse period/pulse width measurement mode, choose functions from those listed in Table 2.3.4. Operations of the circled items are described below. Figure 2.3.10 shows the operation timing, and Figure 2.3.11 shows the set-up procedure.

Table 2.3.4. Choosed functions

| Item         |   | Set-up                                                                                                                            |  |  |  |
|--------------|---|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Count source | 0 | Internal count source (f1 / f8 / f32 / fc32)                                                                                      |  |  |  |
| Measurement  |   | Pulse period measurement (interval between measurement pulse falling edge to falling edge)                                        |  |  |  |
| mode         |   | Pulse period measurement (interval between measurement pulse rising edge to rising edge)                                          |  |  |  |
|              | 0 | Pulse width measurement (interval between measurement pulse falling edge to rising edge, and between rising edge to falling edge) |  |  |  |

Operation (1) Setting the count start flag to "1" causes the counter to start counting the count source.

- (2) If an effective edge of a pulse to be measured is input, the value of the counter goes to "000016", and measurement is started. In this instance, an indeterminate value is transferred to the reload register. The timer Bi interrupt request does not generate.
- (3) If an effective edge of a pulse to be measured is input again, the value of the counter is transferred to the reload register, and the timer Bi interrupt request bit goes to "1". Then the value of the counter becomes "000016", and measurement is started again.

Note

- The timer Bi interrupt request bit goes to "1" when an effective edge of a pulse to be measured is input or timer Bi is overflows. The factor of interrupt request can be determined by use of the timer Bi overflow flag within the interrupt routine.
- The value of the counter at the beginning of a count is indeterminate. Thus there can be instances in which the timer Bi overflow flag goes to "1" immediately after a count is performed.
- The timer Bi overflow flag goes to "0" if timer Bi mode register is written to when the count start flag is "1". This flag cannot be set to "1" by software.



Figure 2.3.10. Operation timing of pulse width measurement mode



Figure 2.3.11. Set-up procedure of pulse width measurement mode

## 2.3.6 Precautions for Timer B (timer mode, event counter mode)

- (1) To clear reset, the count start flag is set to "0". Set a value in the timer Bi register, then set the flag to "1".
- (2) Reading the timer Bi register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the timer Bi register with the reload timing shown in Figure 2.3.12 gets "FFFF16". Reading the timer Bi register after setting a value in the timer Bi register with a count halted but before the counter starts counting gets a proper value.



Figure 2.3.12. Reading timer Bi register

## 2.3.7 Precautions for Timer B (pulse period/pulse width measurement mode)

- (1) The timer Bi interrupt request bit goes to "1" when an effective edge of a measurement pulse is input or timer Bi is overflowed. The factor of interrupt request can be determined by use of the timer Bi overflow flag within the interrupt routine.
- (2) If the timer overflow occurs simultaneously with the input of a measurement pulse, and if the interrupt factor cannot be determined from the timer Bi overflow flag, connect the timers and count the number of overflows.
- (3) When reset, the timer Bi overflow flag goes to "1". This flag cannot be set to "0" by writing to the timer Bi mode register when the count start flag is "1".
- (4) Use the timer Bi interrupt request bit to detect only overflows. Use the timer Bi overflow flag only to determine the interrupt factor within the interrupt routine.
- (5) When the first effective edge is input after a count is started, an indeterminate value is transferred to the reload register. At this time, timer Bi interrupt request is not generated.
- (6) The value of the counter is indeterminate at the beginning of a count. Therefore the timer Bi overflow flag may go to "1" immediately after a count is started.
- (7) If changing the measurement mode select bit is set after a count is started, the timer Bi interrupt request bit goes to "1".
- (8) If the input signal to the TBin pin is affected by noise, precise measurement may not be performed in some cases. It is recommended to see that measurements fall within a specific range by use of software.
- (9) For pulse width measurement, pulse widths are successively measured. Use software to check whether the measurement result is an "H" level width or an "L" level width.



#### 2.4 Timer X

## 2.4.1 Overview

The following is an overview for timer X, a 16-bit timer.

#### (1) Mode

Timer X operates in one of the four modes:

#### (a) Timer mode

In this mode, the internal count source is counted. Two functions can be selected: the pulse output function that reverses output from a port every time an overflow occurs, or the gate function which controls the count start/stop according to the input signal from a port.

| Timer mode operation                        | P212 |
|---------------------------------------------|------|
| Timer mode, gate function operation         | P214 |
| Timer mode, pulse output function operation | P216 |

#### (b) Event counter mode

This mode counts the pulses from the outside and the number of overflows in other timers. The freerun type, in which nothing is reloaded from the reload register, can be selected when an underflow occurs. The pulse output function can also be selected.

| Event counter mode operation | P218 |
|------------------------------|------|
|                              | Door |

## 

#### (c) One-shot timer mode

In this mode, the timer is started by the trigger and stops when the timer goes to "0". The trigger can be selected from the following 3 types: an external input signal, an overflow of the timer, or a software trigger.

## (d) Pulse period measurement/pulse width measurement mode

External pulse period or external pulse widths are measured. If pulse period measurement mode is selected, the periods of input pulses are continuously measured. If pulse width measurement mode is selected, widths of "H" level pulses and those of "L" level pulses are continuously measured.

| Operation in pulse period measurement mode | P224 |
|--------------------------------------------|------|
| Operation in pulse width measurement mode  | P226 |

## (d) Pulse width modulation (PWM) mode

In this mode, the arbitrary pulses are successively output. Either a 16-bit fixed-period PWM mode or 8-bit variable-period mode can be selected. The trigger for initiating output can also be selected.

| • 16-bit PWM mo | node operation | P228 |
|-----------------|----------------|------|
| O L ' DIAMA     |                | 5000 |

#### 

#### (2) Count source

The internal count source can be selected from f1, f8, f32, and fC32. Clocks f1, f8, and f32 are derived by dividing the CPU's main clock by 1, 8, and 32 respectively. Clock fC32 is derived by dividing the CPU's secondary clock by 32.



## (3) Frequency division ratio

In timer mode or pulse width modulation mode, [the value set in the timer register + 1] becomes the frequency division ratio. In event counter mode, [the set value + 1] becomes the frequency division ratio when a down count is performed, or [FFFF16 - the set value + 1] becomes the frequency division ratio when an up count is performed. In one-shot timer mode, the value set in the timer register becomes the frequency division ratio.

The counter overflows (or underflows) when a count source equal to a frequency division ratio is input, and an interrupt occurs. For the pulse output function, the output from the port varies (the value in the port register does not vary).

## (4) Reading the timer

Either in timer mode or in event counter mode, reading the timer register takes out the count at that moment. Read it in 16-bit units. The data either in one-shot timer mode or in pulse width modulation mode is indeterminate. In both the pulse period measurement mode and pulse width measurement mode, an indeterminate value is read until the second effective edge is input after a count is started, otherwise, the measurement results are read.

## (5) Writing to the timer

When writing to the timer register while a count is in progress, the value is written only to the reload register. When writing to the timer register while a count has stopped, the value is written both to the reload register and the count. Write the value in 16-bit increments. The timer register cannot be written to in either the pulse period measurement mode or the pulse width measurement mode.

## (6) Relation between the input/output to/from the timer and the direction register

With the output function of the timer, set the direction register of the relevant port to input. To input an external signal to the timer, set the direction register of the relevant port to input. However, pulse output cannot be selected when inputting an external signal to the timer, and vice-versa.

#### (7) Pins related to timer X

(a) TX0INOUT, TX1INOUT, TX2INOUT Input/output pins to timer X.

## (8) Registers related to timer X

Figure 2.4.1 shows the memory map of timer X-related registers. Figures 2.4.2 and 2.4.3 show timer X-related registers.



Figure 2.4.1. Memory map of timer X-related registers

## Timer X



Figure 2.4.2. Timer X-related registers (1)



Figure 2.4.3. Timer X-related registers (2)

# 2.4.2 Operation of Timer X (timer mode)

In timer mode, choose functions from those listed in Table 2.4.1. Operations of the circled items are described below. Figure 2.4.4 shows the operation timing, and Figure 2.4.5 shows the set-up procedure.

Table 2.4.1. Choosed functions

| Item                  |   | Set-up                                                                       |
|-----------------------|---|------------------------------------------------------------------------------|
| Count source          | 0 | Internal count source (f1 / f8 / f32 / fc32)                                 |
| Pulse output function | 0 | No pulses output                                                             |
|                       |   | Pulses output                                                                |
| Gate function         | 0 | No gate function                                                             |
|                       |   | Performs count only for the period in which the TXiINOUT pin is at "L" level |
|                       |   | Performs count only for the period in which the TXiINOUT pin is at "H" level |

Operation (1) Setting the count start flag to "1" causes the counter to perform a down count on the count source.

- (2) If an underflow occurs, the content of the reload register is reloaded, and the count continues. At this time, the timer Xi interrupt request bit goes to "1".
- (3) Setting the count start flag to "0" causes the counter to hold its value and to stop.



Figure 2.4.4. Operation timing of timer mode



Figure 2.4.5. Set-up procedure of timer mode

## 2.4.3 Operation of Timer X (timer mode, gate function selected)

In timer mode, choose functions from those listed in Table 2.4.2. Operations of the circled items are described below. Figure 2.4.6 shows the operation timing, and Figure 2.4.7 shows the set-up procedure.

Table 2.4.2. Choosed functions

| Item                  |   | Set-up                                                                       |
|-----------------------|---|------------------------------------------------------------------------------|
| Count source          | 0 | Internal count source (f1 / f8 / f32 / fc32)                                 |
| Pulse output function | 0 | No pulses output                                                             |
|                       |   | Pulses output                                                                |
| Gate function         |   | No gate function                                                             |
|                       |   | Performs count only for the period in which the TXiINOUT pin is at "L" level |
|                       | 0 | Performs count only for the period in which the TXiINOUT pin is at "H" level |

Operation (1) When the count start flag is set to "1" and the TXiINOUT pin inputs at "H" level, the counter performs a down count on the count source.

- (2) When the TXiINOUT pin inputs at "L" level, the counter holds its value and stops.
- (3) If an underflow occurs, the content of the reload register is reloaded and the count continues. At this time, the timer Xi interrupt request bit goes to "1".
- (4) Setting the count start flag to "0" causes the counter to hold its value and to stop.

Note

 Make the pulse width of the signal input to the TXiINOUT pin not less than two cycles of the count source.



Figure 2.4.6. Operation timing of timer mode, gate function selected



Figure 2.4.7. Set-up procedure of timer mode, gate function selected

## 2.4.4 Operation of Timer X (timer mode, pulse output function selected)

In timer mode, choose functions from those listed in Table 2.4.3. Operations of the circled items are described below. Figure 2.4.8 shows the operation timing, and Figure 2.4.9 shows the set-up procedure.

Table 2.4.3. Choosed functions

| Item                  |   | Set-up                                                                       |  |
|-----------------------|---|------------------------------------------------------------------------------|--|
| Count source          | 0 | Internal count source (f1 / f8 / f32 / fc32)                                 |  |
| Pulse output function |   | No pulses output                                                             |  |
|                       | 0 | Pulses output                                                                |  |
| Gate function         | 0 | No gate function                                                             |  |
|                       |   | Performs count only for the period in which the TXiINOUT pin is at "L" level |  |
|                       |   | Performs count only for the period in which the TXiINOUT pin is at "H" level |  |

- Operation (1) Setting the count start flag to "1" causes the counter to perform a down count on the count source.
  - (2) If an underflow occurs, the content of the reload register is reloaded and the count continues. At this time, the timer Xi interrupt request bit goes to "1". Also, the output polarity of the TXIINOUT pin reverses.
  - (3) Setting the count start flag to "0" causes the counter to hold its value and to stop. Also, the TXiINOUT pin outputs an "L" level.



Figure 2.4.8. Operation timing of timer mode, pulse output function selected



Figure 2.4.9. Set-up procedure of timer mode, pulse output function selected

# 2.4.5 Operation of Timer X (event counter mode, reload type selected)

In event counter mode, choose functions from those listed in Table 2.4.4. Operations of the circled items are described below. Figure 2.4.10 shows the operation timing, and Figure 2.4.11 shows the set-up procedure.

Table 2.4.4. Choosed functions

| Item                  |   | Set-up                                           |
|-----------------------|---|--------------------------------------------------|
| Count source          |   | Input signal to TXiINOUT(counting falling edges) |
|                       |   | Input signal to TXiiNout(counting rising edges)  |
|                       | 0 | Timer overflow(TB1/TA0/TXi overflow)             |
| Pulse output function |   | No pulses output                                 |
|                       | 0 | Pulses output                                    |
| Count operation type  | 0 | Reload type                                      |
|                       |   | Free-run type                                    |

- Operation (1) Setting the count start flag to "1" causes the counter to count the falling edges of the count source.
  - (2) If an underflow occurs, the content of the reload register is reloaded, and the count continues. At this time, the timer Xi interrupt request bit goes to "1".
  - (3) Setting the count start flag to "0" causes the counter to hold its value and to stop.



Figure 2.4.10. Operation timing of event counter mode, reload type selected



Figure 2.4.11. Set-up procedure of event counter mode, reload type selected

## 2.4.6 Operation of Timer X (event counter mode, free run type selected)

In event counter mode, choose functions from those listed in Table 2.4.5. Operations of the circled items are described below. Figure 2.4.12 shows the operation timing, and Figure 2.4.13 shows the set-up procedure.

Table 2.4.5. Choosed functions

| Item                  |   | Set-up                                           |
|-----------------------|---|--------------------------------------------------|
| Count source          | 0 | Input signal to TXiINOUT(counting falling edges) |
|                       |   | Input signal to TXiINOUT(counting rising edges)  |
|                       |   | Timer overflow(TB1/TA0/TXi overflow)             |
| Pulse output function | 0 | No pulses output                                 |
|                       |   | Pulses output                                    |
| Count operation type  |   | Reload type                                      |
|                       | 0 | Free-run type                                    |

Operation (1) Setting the count start flag to "1" causes the counter to count the falling edges of the count source.

- (2) Even if an underflow occurs, the content of the reload register is not reloaded, but the count continues. At this time, the timer Xi interrupt request bit goes to "1".
- (3) Setting the count start flag to "0" causes the counter to hold its value and to stop.



Figure 2.4.12. Operation timing of event counter mode, free run type selected



Figure 2.4.13. Set-up procedure of event counter mode, free run type selected



## 2.4.7 Operation of Timer X (one-shot timer mode)

In one-shot timer mode, choose functions from those listed in Table 2.4.6. Operations of the circled items are described below. Figure 2.4.14 shows the operation timing, and Figure 2.4.15 shows the set-up procedure.

Table 2.4.6. Choosed functions

| Item                  |   | Set-up                                                                    |
|-----------------------|---|---------------------------------------------------------------------------|
| Count source          | 0 | Internal count source (f1 / f8 / f32 / fc32)                              |
| Pulse output function |   | No pulses output                                                          |
|                       | 0 | Pulses output                                                             |
| Count start condition |   | External trigger input (falling edge of input signal to the TXiINOUT pin) |
|                       |   | External trigger input (rising edge of input signal to the TXiINOUT pin)  |
|                       |   | Timer overflow (TB1/TX0/TXi overflow)                                     |
|                       | 0 | Writing "1" to the one-shot start flag                                    |

Operation (1) Setting the one-shot start flag to "1" with the count start flag set to "1" causes the counter to perform a down count on the count source. At this time, the TXIINOUT pin outputs an "H" level.

- (2) The instant the value of the counter becomes "000016", the TXIINOUT pin outputs an "L" level, and the counter reloads the content of the reload register and stops counting. At this time, the timer Xi interrupt request bit goes to "1".
- (3) If a trigger occurs while a count is in progress, the counter reloads the value in the reload register again and continues counting. The reload timing is in step with the next count source input after the trigger.
- (4) Setting the count start flag to "0" causes the counter to stop and to reload the content of the reload register. Also, the TXiINOUT pin outputs an "L" level. At this time, the timer Xi interrupt request bit goes to "1".



Figure 2.4.14. Operation timing of one-shot mode



Figure 2.4.15. Set-up procedure of one-shot mode



## 2.4.8 Operation of Timer X (pulse period measurement mode)

In pulse period/pulse width measurement mode, choose functions from those listed in Table 2.4.7. Operations of the circled items are described below. Figure 2.4.16 shows the operation timing, and Figure 2.4.17 shows the set-up procedure.

Table 2.4.7. Choosed functions

| Item         |   | Set-up                                                                                                                            |  |  |  |  |
|--------------|---|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Count source | 0 | Internal count source (f1 / f8 / f32 / fc32)                                                                                      |  |  |  |  |
| Measurement  | 0 | Pulse period measurement (interval between measurement pulse falling edge to falling edge)                                        |  |  |  |  |
| mode         |   | Pulse period measurement (interval between measurement pulse rising edge to rising edge)                                          |  |  |  |  |
|              |   | Pulse width measurement (interval between measurement pulse falling edge to rising edge, and between rising edge to falling edge) |  |  |  |  |

- Operation (1) Setting the count start flag to "1" causes the counter to start counting the count source.
  - (2) If a measurement pulse changes from "H" to "L", the value of the counter goes to "000016", and measurement is started. In this instance, an indeterminate value is transferred to the reload register. The timer Xi interrupt request does not generate.
  - (3) If a measurement pulse changes from "H" to "L" again, the value of the counter is transferred to the reload register, and the timer Xi interrupt request bit goes to "1". Then the value of the counter becomes "000016", and the measurement is started again.

Note

- The timer Xi interrupt request bit goes to "1" when an effective edge of a measurement pulse is input or timer Xi is overflowed. The factor of interrupt request can be determined by use of the timer Xi overflow flag within the interrupt routine.
- The value of the counter at the beginning of a count is indeterminate. Thus there can be instances in which the timer Xi overflow flag goes to "1" immediately after a count is performed.
- The timer Xi overflow flag goes to "0" if timer Xi mode register is written to when the count start flag is "1". This flag cannot be set to "1" by software.



Figure 2.4.16. Operation timing of pulse period measurement mode



Figure 2.4.17. Set-up procedure of pulse period measurement mode



## 2.4.9 Operation of Timer X (pulse width measurement mode)

In pulse period/pulse width measurement mode, choose functions from those listed in Table 2.4.8. Operations of the circled items are described below. Figure 2.4.18 shows the operation timing, and Figure 2.4.19 shows the set-up procedure.

Table 2.4.8. Choosed functions

| Item         |   | Set-up                                                                                                                            |  |  |
|--------------|---|-----------------------------------------------------------------------------------------------------------------------------------|--|--|
| Count source | 0 | Internal count source (f1 / f8 / f32 / fc32)                                                                                      |  |  |
| Measurement  |   | Pulse period measurement (interval between measurement pulse falling edge to falling edge)                                        |  |  |
| mode         |   | Pulse period measurement (interval between measurement pulse rising edge to rising edge)                                          |  |  |
|              | 0 | Pulse width measurement (interval between measurement pulse falling edge to rising edge, and between rising edge to falling edge) |  |  |

Operation (1) Setting the count start flag to "1" causes the counter to start counting the count source.

- (2) If an effective edge of a pulse to be measured is input, the value of the counter goes to "000016", and measurement is started. In this instance, an indeterminate value is transferred to the reload register. The timer Xi interrupt request does not generate.
- (3) If an effective edge of a pulse to be measured is input again, the value of the counter is transferred to the reload register, and the timer Xi interrupt request bit goes to "1". Then the value of the counter becomes "000016", and measurement is started again.

Note

- The timer Xi interrupt request bit goes to "1" when an effective edge of a pulse to be measured is input or timer Xi is overflows. The factor of interrupt request can be determined by use of the timer Xi overflow flag within the interrupt routine.
- The value of the counter at the beginning of a count is indeterminate. Thus there can be instances in which the timer Xi overflow flag goes to "1" immediately after a count is performed.
- The timer Xi overflow flag goes to "0" if timer Xi mode register is written to when the count start flag is "1". This flag cannot be set to "1" by software.



Figure 2.4.18. Operation timing of pulse width measurement mode



Figure 2.4.19. Set-up procedure of pulse width measurement mode



## 2.4.10 Operation of Timer X (pulse width modulation mode, 16-bit PWM mode selected)

In pulse width modulation mode, choose functions from those listed in Table 2.4.9. Operations of the circled items are described below. Figure 2.4.20 shows the operation timing, and Figure 2.4.21 shows the set-up procedure.

Table 2.4.9. Choosed functions

| Item                  | Set-up |                                              |  |
|-----------------------|--------|----------------------------------------------|--|
| Count source          | 0      | Internal count source (f1 / f8 / f32 / fc32) |  |
| PWM mode              | 0      | 16-bit PWM                                   |  |
|                       |        | 8-bit PWM                                    |  |
| Count start condition | 0      | Timer overflow (TB1/TA0/TXi overflow)        |  |

Operation (1) Selected timer overflow is generated with the count start flag set to "1", the counter performs a down count on the count source. Also, the TXIINOUT pin outputs an "H" level.

- (2) The TXiINOUT pin output level changes from "H" to "L" when a set time period elapses. At this time, the timer Xi interrupt request bit goes to "1".
- (3) The counter reloads the content of the reload register every time PWM pulses are output for one cycle, and continues counting.
- (4) Setting the count start flag to "0" causes the counter to hold its value and to stop. Also, the TXIINOUT outputs an "L" level.

Note

• PWM pulse cycle is (2<sup>16</sup> -1)/fi, whereas "H" level duration is n/fi. However, when "000016" is set for the timer A0 register, the PWM output is "L" level for the entire period, and an interrupt request is generated for every PWM output cycle. Also, when "FFFF16" is set for the timer A0 register, the PWM output is "H" level for the entire period, and an interrupt request is generated for every PWM output cycle.

(fi: Count source frequency f1, f8, f32, fC32 n: Timer value)



Figure 2.4.20. Operation timing of pulse width modulation mode, 16-bit PWM mode selected



Figure 2.4.21. Set-up procedure of pulse width modulation mode, 16-bit PWM mode selected



## 2.4.11 Operation of Timer X (pulse width modulation mode, 8-bit PWM mode selected)

In pulse width modulation mode, choose functions from those listed in Table 2.4.10. Operations of the circled items are described below. Figure 2.4.22 shows the operation timing, and Figure 2.4.22 shows the set-up procedure.

Table 2.4.10. Choosed functions

| Item                  | Set-up |                                              |  |
|-----------------------|--------|----------------------------------------------|--|
| Count source          | 0      | Internal count source (f1 / f8 / f32 / fc32) |  |
| PWM mode              |        | 16-bit PWM                                   |  |
|                       | 0      | 8-bit PWM                                    |  |
| Count start condition | 0      | Timer overflow (TB1/TA0/TXi overflow)        |  |

Operation (1) Selected timer overflow is generated with the count start flag set to "1", the counter performs a down count on the count source. Also, the TXiINOUT pin outputs an "H" level.

- (2) The TXiINOUT pin output level changes from "H" to "L" when a set time period elapses. At this time, the timer Xi interrupt request bit goes to "1".
- (3) The counter reloads the content of the reload register every time PWM pulses are output for one cycle, and continues counting.
- (4) Setting the count start flag to "0" causes the counter to hold its value and to stop. Also, the TXiout pin outputs an "L" level.

Note

• PWM pulse cycle is (m + 1( x (2<sup>8</sup> -1)/fi, whereas "H" level duration is n x (m + 1)/fi. However, when "0016" is set for the significant 8 bits of the timer A0 register, the PWM output is "L" level for the entire period, and an interrupt request is generated for every PWM output cycle. Also, when "FF16" is set for the significant 8 bits of the timer A0 register, the PWM output is "H" level for the entire period, and an interrupt request is generated for every PWM output cycle. (fi: Count source frequency f1, f8, f32, fc32 n: Timer value)



Figure 2.4.22. Operation timing of pulse width modulation mode, with 8-bit PWM mode selected



Figure 2.4.23. Set-up procedure of pulse width modulation mode, 8-bit PWM mode selected

## 2.4.12 Precautions for Timer X (timer mode, event counter mode)

- (1) To clear reset, the count start flag is set to "0". Set a value in the timer Xi register, then set the flag to "1".
- (2) Reading the timer Xi register while a count is in progress allows reading, with arbitrary timing, the value of the counter. Reading the timer Xi register with the reload timing shown in Figure 2.4.24 gets "FFFF16". Reading the timer Xi register after setting a value in the timer Xi register with a count halted but before the counter starts counting gets a proper value.



Figure 2.4.24. Reading timer Xi register

## 2.4.13 Precautions for Timer X (one-shot timer mode)

- (1) To clear reset, the count start flag is set to "0". Set a value in the timer Xi register, then set the flag to "1".
- (2) Setting the count start flag to "0" while a count is in progress causes as follows:
  - The counter stops counting and a content of reload register is reloaded.
  - The TXiINOUT pin outputs "L" level.
  - The interrupt request generated and the timer Xi interrupt request bit goes to "1".
- (3) The timer Xi interrupt request bit goes to "1" if the timer's operation mode is set using any of the following procedures:
  - Selecting one-shot timer mode after reset.
  - Changing operation mode from timer mode to one-shot timer mode.
  - Changing operation mode from event counter mode to one-shot timer mode.

Therefore, to use timer Xi interrupt (interrupt request bit), set timer Xi interrupt request bit to "0" after the above listed changes have been made.

(4) If a trigger occurs while a count is in progress, after the counter performs one down count following the reoccurrence of a trigger, the reload register contents are reloaded, and the count continues. To generate a trigger while a count is in progress, generate the second trigger after an elapse longer than one cycle of the timer's count source after the previous trigger occurred.



## 2.4.14 Precautions for Timer X (pulse period/pulse width measurement mode)

- (1) The timer Xi interrupt request bit goes to "1" when an effective edge of a measurement pulse is input or timer Xi is overflowed. The factor of interrupt request can be determined by use of the timer Xi overflow flag within the interrupt routine.
- (2) If the timer overflow occurs simultaneously with the input of a measurement pulse, and if the interrupt factor cannot be determined from the timer Xi overflow flag, connect the timers and count the number of overflows.
- (3) When reset, the timer Xi overflow flag goes to "1". This flag cannot be set to "0" by writing to the timer Xi mode register when the count start flag is "1".
- (4) Use the timer Xi interrupt request bit to detect only overflows. Use the timer Xi overflow flag only to determine the interrupt factor within the interrupt routine.
- (5) When the first effective edge is input after a count is started, an indeterminate value is transferred to the reload register. At this time, timer Xi interrupt request is not generated.
- (6) The value of the counter is indeterminate at the beginning of a count. Therefore the timer Xi overflow flag may go to "1" immediately after a count is started.
- (7) If changing the measurement mode select bit is set after a count is started, the timer Xi interrupt request bit goes to "1".
- (8) If the input signal to the TXiINOUT pin is affected by noise, precise measurement may not be performed in some cases. It is recommended to see that measurements fall within a specific range by use of software.
- (9) For pulse width measurement, pulse widths are successively measured. Use software to check whether the measurement result is an "H" level width or an "L" level width.

## 2.4.15 Precautions for Timer X (pulse width modulation mode)

- (1) To clear reset, the count start flag is set to "0". Set a value in the timer Xi register, then set the flag to "1".
- (2) The timer Xi interrupt request bit becomes "1" if setting operation mode of the timer in compliance with any of the following procedures:
  - Selecting PWM mode after reset.
  - Changing operation mode from timer mode to PWM mode.
  - Changing operation mode from event counter mode to PWM mode.

Therefore, to use timer Xi interrupt (interrupt request bit), set timer Xi interrupt request bit to "0" after the above listed changes have been made.

- (3) Setting the count start flag to "0" while PWM pulses are being output causes the counter to stop counting. If the TXiINOUT pin is outputting an "H" level in this instance, the output level goes to "L", and the timer Xi interrupt request bit goes to "1". If the TXiINOUT pin is outputting an "L" level in this instance, the level does not change, and the timer Xi interrupt request bit does not becomes "1".
- (4) Normal PWM output is restored according to the interrupt request generate timing, both in the case of 16-bit PWM and 8-bit PWM, when PWM output is either "H" or "L" level for the entire period. This holds only when a value other than "000016" or "FFFF16" is set during 16-bit PWM, or a value other than "0016" or "FF16" is set during 8-bit PWM.



Figure 2.4.25. Operation timing of PWM output mode

## 2.5 Clock-Synchronous Serial I/O

## 2.5.1 Overview

Clock-synchronous serial I/O carries out 8-bit data communications in synchronization with the clock. The following is an overview of the clock-synchronous serial I/O.

## (1) Transmission/reception format

8-bit data

#### (2) Transfer rate

If the internal clock is selected as the transfer clock, the divide-by-2 frequency, resulting from the bit rate generator division, becomes the transfer rate. The bit rate generator count source can be selected from the following: f1, f8, f32, and fc. Clocks f1, f8 and f32 are derived by dividing the CPU's main clock by 1, 8, and 32 respectively. Clock fc is derived by dividing the CPU's sub clock by 1 respectively.

Furthermore, if an external clock is selected as the transfer clock, the clock frequency input to the CLK pin becomes the transfer rate.

#### (3) Error detection

Only overrun error can be detected. Overrun error is an error that occurs when the next data is made ready before the reception buffer register is read.

#### (4) How to deal with an error

When receiving data, read an error flag and reception data simultaneously to determine which error has occurred. If the data read is erroneous, initialize the error flag and the UART0 receive buffer register, then receive the data again.

## To initialize the UART0 receive buffer register

- 1. Set the receive enable bit to "0" (disable reception).
- 2. Set the serial I/O mode select bit to "0002" (invalid serial I/O).
- 3. Set the serial I/O mode select bit.
- 4. Set the receive enable bit to "1" again (enable reception).

To transmit data again due to an error on the reception side when external clock is selected, clear the UART0 transmit buffer register, then transmit the data again.

#### To clear the UART0 transmit buffer register

- 1. Set the port P52 (CLKo pin) direction register to "0" (input mode).
- 2. Set the port P50 (TxD0 pin) direction register to "0" (input mode).
- 3. Set the internal/external clock select bit to "0" (internal clock).
- 4. Checking complection of transmission (no data present in transmit register).
- 5. Set the internal/external clock select bit to "1" (external clock).
- 6. Set the port P50 (TxD0 pin) direction register to "1" (output mode), then set transmission data in the UART0 transmit buffer register.

#### (5) Function selection

For clock-synchronous serial I/O, the following functions can be selected:

#### (a) Function for choosing polarity

This function switches the polarity of the transfer clock. The following operations are available:

- Data is input at the falling edge of the transfer clock, and is output at the rising edge.
- Data is input at the rising edge of the transfer clock, and is output at the falling edge.

#### (b) Function for choosing which bit to transmit first

This function is to choose whether to transmit data from bit 0 or from bit 7. Choose either of the following:

LSB first Data is transmitted from bit 0.
MSB first Data is transmitted from bit 7.

## (c) Function for choosing successive reception mode

Successive reception mode is a mode in which reading the receive buffer register makes the reception-enabled status ready. In this mode, there is no need to write dummy data to the transmit buffer register so as to make the reception-enabled status ready. But at the time of starting reception, read the receive buffer register into a dummy manner.

Normal mode
 Writing dummy data to the transmit buffer register makes the

reception enabled status ready.

Successive reception mode
 Reading the reception buffer register makes the reception-enabled

status ready.

#### (d) Function for outputting transfer clock to multiple pins

This function is to switch among pins to output the transfer clock. This function is effective only when selecting the internal clock. Switching among pins for outputting the transfer clock allows data transmission to two external ICs in a time-sharing manner.

## (e) Function for choosing a transmission interrupt factor

The timing to generate a transmission interrupt can be selected from the following: the instant the transmission buffer is emptied or the instant the transmission register is emptied. When transmission buffer empty timing is selected, an interrupt occurs when transmitted data is moved from the transmission buffer to the transmission register. Therefore, data can be transmitted in succession. When transmission register empty timing is selected, an interrupt occurs when data transmission is complete.

Following are some examples in which various functions (a) through (e) are selected:

- Transmission Operation WITH: transmission at falling edge of transfer clock, LSB First, interrupt at instant transmission buffer is emptied; WITHOUT transfer clock output to multiple pins function ...

#### (6) Input/output to the serial I/O and the direction register

To input an external signal to the serial I/O, set the direction register of the relevant port to input. To output signal from the serial I/O, set the direction register of the relevant port to output.

#### (7) Pins related to the serial I/O

CLK0 pin Input/output pins for the transfer clock

• RxD0, RxD1 pins Input pins for data

• TxD0, TxD1 pins Output pins for data (Since TxD2 pin is N-channel open drain, this pin needs

pull-up resistor.)

CLKS pin
 Output pin for transfer clock. Can be used as transfer clock output pin in the

transfer clock output to multiple pins function.

Note: UART1 cannot be used in clock-synchronous serial I/O mode.

#### (8) Registers related to the serial I/O

Figure 2.5.1 shows the memory map of serial I/O-related registers, and Figures 2.5.2 to 2.5.4 show serial I/O-related registers.



Figure 2.5.1. Memory map of serial I/O-related registers



Figure 2.5.2. Serial I/O-related registers (1)



Figure 2.5.3. Serial I/O-related registers (2)



Figure 2.5.4. Serial I/O-related registers (3)

# 2.5.2 Operation of Serial I/O (transmission in clock-synchronous serial I/O mode)

In transmitting data in clock-synchronous serial I/O mode, choose functions from those listed in Table 2.5.1. Operations of the circled items are described below. Figure 2.5.5 shows the operation timing, and Figures 2.5.6 and 2.5.7 show the set-up procedures.

Table 2.5.1. Choosed functions

| Item                       |   | Set-up                                                             |
|----------------------------|---|--------------------------------------------------------------------|
| Transfer clock             | 0 | Internal clock (f1 / f8 / f32 / fc)                                |
| source                     |   | External clock (CLK0 pin)                                          |
| CLK polarity               | 0 | Output transmission data at the falling edge of the transfer clock |
|                            |   | Output transmission data at the rising edge of the transfer clock  |
| Transfer clock             | 0 | LSB first                                                          |
|                            |   | MSB first                                                          |
| Transmission               | 0 | Transmission buffer empty                                          |
| interrupt factor           |   | Transmission complete                                              |
| Output transfer clock      | 0 | Not selected                                                       |
| to multiple pins<br>(Note) |   | Selected                                                           |

Note: This can be selected only when UART0 is used in combination with the internal clock.

Operation (1) Setting the transmit enable bit to "1" and writing transmission data to the UART0 transmit buffer register makes data transmissible status ready.

- (2) In synchronization with the first falling edge of the transfer clock, transmission data held in the UART0 transmit buffer register is transmitted to the UART0 transmit register. At this time, the UART0 transmit interrupt request bit goes to "1". Also, the first bit of the transmission data is transmitted from the TxDo pin. Then the data is transmitted bit by bit from the lower order in synchronization with the falling edges.
- (3) When transmission of 1-byte data is completed, the transmit register empty flag goes to "1", which indicates that transmission is completed. The transfer clock stops at "H" level.
- (4) If the next transmission data is set in the UART0 transmit buffer register while transmission is in progress (before the eighth bit has been transmitted), the data is transmitted in succession.



Figure 2.5.5. Operation timing of transmission in clock-synchronous serial I/O mode



Figure 2.5.6. Set-up procedure of transmission in clock-synchronous serial I/O mode (1)



Figure 2.5.7. Set-up procedure of transmission in clock-synchronous serial I/O mode (2)

# 2.5.3 Operation of the Serial I/O (transmission in clock-synchronous serial I/O mode, transfer clock output from multiple pins function selected)

In transmitting data in clock-synchronous serial I/O mode, choose functions from those listed in Table 2.5.2. Operations of the circled items are described below. Figure 2.5.8 shows the operation timing, and Figures 2.5.9 and 2.5.10 show the set-up procedures.

Table 2.5.2. Choosed functions

| Item                    | Set-up |                                                                    |  |
|-------------------------|--------|--------------------------------------------------------------------|--|
| Transfer clock          | 0      | Internal clock (f1 / f8 / f32 / fc)                                |  |
| source                  |        | External clock (CLK0 pin)                                          |  |
| CLK polarity            | 0      | Output transmission data at the falling edge of the transfer clock |  |
|                         |        | Output transmission data at the rising edge of the transfer clock  |  |
| Transfer clock          | 0      | LSB first                                                          |  |
|                         |        | MSB first                                                          |  |
| Transmission            | 0      | Transmission buffer empty                                          |  |
| interrupt factor        |        | Transmission complete                                              |  |
| Output transfer clock   |        | Not selected                                                       |  |
| to multiple pins (Note) | 0      | Selected                                                           |  |

Note: This can be selected only when UART0 is used in combination with the internal clock.

Operation (1) Setting the transmit enable bit to "1" makes data transmissible status ready.

- (2) When transmission data is written to the UART0 transmit buffer register, transmission data held in the UART0 transmit buffer register is transmitted to the UART0 transmit register in synchronization with the first falling edge of the transfer clock. At this time, the first bit of the transmission data is transmitted from the TxD0 pin. Then the data is transmitted bit by bit from the lower order in synchronization with the falling edges of the transfer clock.
- (3) When transmission of 1-byte data is completed, the transmit register empty flag goes to "1", which indicates that the transmission is completed. The transfer clock stops at "H" level. At this time, the UART0 transmit interrupt request bit goes to "1".
- (4) Setting CLK/CLKS select bit 1 to "1" and setting CLK/CLKS select bit 0 to "1" causes the CLKS pin to go to the transfer clock output pin. Change the transfer clock output pin when transmission is halted.



Figure 2.5.8. Operation timing of transmission in clock-synchronous serial I/O mode, transfer clock output from multiple pins function selected



Figure 2.5.9. Set-up procedure of transmission in clock-synchronous serial I/O mode, transfer clock output from multiple pins function selected (1)



Figure 2.5.10. Set-up procedure of transmission in clock-synchronous serial I/O mode, transfer clock output from multiple pins function selected (2)

# 2.5.4 Operation of Serial I/O (reception in clock-synchronous serial I/O mode)

In receiving data in clock-synchronous serial I/O mode, choose functions from those listed in Table 2.5.3. Operations of the circled items are described below. Figure 2.5.11 shows the operation timing, and Figures 2.5.12 and 2.5.13 show the set-up procedures.

Table 2.5.3. Choosed functions

| Item                                   | Set-up |                                                                    |  |
|----------------------------------------|--------|--------------------------------------------------------------------|--|
| Transfer clock                         |        | Internal clock (f1 / f8 / f32 / fc)                                |  |
| source                                 | 0      | External clock (CLK0 pin)                                          |  |
| CLK polarity                           | 0      | Output transmission data at the falling edge of the transfer clock |  |
|                                        |        | Output transmission data at the rising edge of the transfer clock  |  |
| Transfer clock                         | 0      | LSB first                                                          |  |
|                                        |        | MSB first                                                          |  |
| Continuous receive                     | 0      | Disabled                                                           |  |
| mode                                   |        | Enabled                                                            |  |
| Output transfer clock to multiple pins | 0      | Not selected                                                       |  |
| (Note)                                 |        | Selected                                                           |  |

Note: This can be selected only when UART0 is used in combination with the internal clock.

Operation (1) Writing dummy data to the UART0 transmit buffer register, setting the receive enable bit to "1", and the transmit enable bit to "1", makes the data receivable status ready.

- (2) In synchronization with the first rising edge of the transfer clock, the input signal to the RxD0 pin is stored in the highest bit of the UART0 receive register. Then, data is taken in by shifting right the content of the UART0 reception data in synchronization with the rising edges of the transfer clock.
- (3) When 1-byte data lines up in the UART0 receive register, the content of the UART0 receive register is transmitted to the UART0 receive buffer register. The transfer clock stops at "H" level. At this time, the receive complete flag and the UART0 receive interrupt request bit goes to "1".
- (4) The receive complete flag goes to "0" when the lower-order byte of the UART0 buffer register is read.



Figure 2.5.11. Operation timing of reception in clock-synchronous serial I/O mode



Figure 2.5.12. Set-up procedure of reception in clock-synchronous serial I/O mode (1)



Figure 2.5.13. Set-up procedure of reception in clock-synchronous serial I/O mode (2)

# 2.5.5 Precautions for Serial I/O (in clock-synchronous serial I/O)

# Transmission

- (1) With an external clock selected, perform the following set-up procedure with the CLK0 pin input level = "H" if the CLK polarity select bit = "0" or with the CLK0 pin input level = "L" if the CLK polarity select bit = "1":
  - 1. Set the transmit enable bit (to "1")
  - 2. Write transmission data to the UART0 transmit buffer register

- Reception (1) In operating the clock-synchronous serial I/O, operating a transmitter generates a shift clock. Fix settings for transmission even when using the device only for reception. Dummy data is output to the outside from the TxDo pin (transmission pin) when receiving data.
  - (2) With the internal clock selected, setting the transmit enable bit to "1" (transmission-enabled status) and setting dummy data in the UARTO transmission buffer register generates a shift clock.
    - With the external clock selected, a shift clock is generated when the transmit enable bit is set to "1", dummy data is set in the UART0 transmit buffer register, and the external clock is input to the CLK0 pin.
  - (3) In receiving data in succession, an overrun error occurs when the next reception data is made ready in the UARTO receive register with the receive complete flag set to "1" (before the content of the UARTO receive buffer register is read), and overrun error flag is set to "1". In this instance, the next data is written to the UARTO receive buffer register, so handle with this problem by writing programs on transmission side and reception side so that the previous data is transmitted again.
    - If an overrun error occurs, the UART0 receive interrupt request bit does not go to "1".
  - (4) To receive data in succession, set dummy data in the lower-order byte of the UART0 transmit buffer register every time reception is made.
  - (5) With an external clock selected, perform the following set-up procedure with the CLK0 pin input level = "H" if the CLK polarity select bit = "0" or with the CLK0 pin input level = "L" if the CLK polarity select bit = "1":
    - 1. Set receive enable bit (to "1")
    - 2. Set transmit enable bit (to "1")
    - 3. Write dummy data to the UART0 transmit buffer register



# 2.6 Clock-Asynchronous Serial I/O (UART)

# 2.6.1 Overview

UART handles communications by means of character-by-character synchronization. The transmission side and the reception side are independent of each other, so full-duplex communication is possible. The following is an overview of the clock-asynchronous serial I/O.

# (1) Transmission/reception format

Figure 2.6.1 shows the transmission/reception format, and Table 2.6.1 shows the names and functions of transmission data.



Figure 2.6.1. Transmission/reception format

Table 2.6.1. Transmission data names and functions

| Name                  | Function                                                                                                                                                                                                                                                              |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ST (start bit)        | A 1-bit "L" signal to be added immediately before character bits.  This bit signals the start of data transmission.                                                                                                                                                   |
| DATA (character bits) | Transmission data set in the UARTi transmit buffer register.                                                                                                                                                                                                          |
| PAR (parity bit)      | A signal to be added immediately after character bits so as to increase data reliability. The level of this signal so varies that the total number of 1's in character bits and this bit always becomes even or odd depending on which parity is chosen, even or odd. |
| SP (stop bit)         | Either 1-bit or 2-bit "H" signal to be added immediately after character bits (after the parity bit if parity is checked). This / they signals the end of data transmission.                                                                                          |

# (2) Transfer rate

The divide-by-16 frequency, resulting from division in the bit rate generator (BRG), becomes the transfer rate. The count source for the transfer rate register can be selected from f1, f8, f32, and the input from the CLK pin. Clocks f1, f8, f32 are derived by dividing the CPU's main clock by 1, 8, and 32 respectively.

Table 2.6.2. Example of baud rate setting

| Baud rate | BRG's        | System clo             | ck : 10MHz        | System clock : 7.3728MHz |                   |
|-----------|--------------|------------------------|-------------------|--------------------------|-------------------|
| (bps)     | count source | BRG's set value : n    | Actual time (bps) | BRG's set value : n      | Actual time (bps) |
| 600       | f8           | 129 (8116)             | 600               | 95 (5F <sub>16</sub> )   | 600               |
| 1200      | f8           | 64 (4016)              | 1201              | 47 (2F <sub>16</sub> )   | 1200              |
| 2400      | f8           | 32 (2016)              | 2367              | 23 (1716)                | 2400              |
| 4800      | f1           | 129 (8116)             | 4807              | 95 (5F <sub>16</sub> )   | 4800              |
| 9600      | f1           | 64 (4016)              | 9615              | 47 (2F <sub>16</sub> )   | 9600              |
| 14400     | f1           | 42 (2A <sub>16</sub> ) | 14534             | 31 (1F <sub>16</sub> )   | 14400             |
| 19200     | f1           | 32 (2016)              | 18939             | 23 (1716)                | 19200             |
| 28800     | f1           | 21 (1516)              | 28409             | 15 (F <sub>16</sub> )    | 28800             |
| 31250     | f1           | 19 (1316)              | 31250             |                          |                   |



# (3) An error detection

In clock-asynchronous serial I/O mode, detect errors are shown in Table 2.6.3.

Table 2.6.3. Error detection

| Type of error  | Description                                                                                                                                                                                                                               | When the flag turns on                                                         | How to clear the flag                                                                          |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| Overrun error  | This error occurs when the next data lines up before the content of the UARTi receive buffer register is read. The next data is written to the UARTi receive buffer register. The UARTi receive interrupt request bit does not go to "1". | The average detected                                                           | • Set the receive enable bit to "0".                                                           |
| Framing error  | This error occurs when the<br>stop bit falls short of the set<br>number of stop bits.                                                                                                                                                     | The error is detected when data is transferred from the UARTi receive register | Set the receive enable bit to "0".      Read the lower-order byte of the UARTi receive buffer. |
| Parity error   | With parity enabled, this error occurs when the total number of 1's in character bits and the parity bit is different from the specified number.                                                                                          | to the UARTi receive buffer register.                                          | register.                                                                                      |
| Error-sum flag | This flag turns on when any<br>error (overrun, framing, or<br>parity) is detected.                                                                                                                                                        |                                                                                | When all error (overrun,<br>framing, and parity) are<br>removed, the flag is cleared.          |



#### (4) Functions selection

In operating UART, the following functions can be used:

#### (a) Sleep mode

Sleep mode is a mode in which data is transferred to a particular microcomputer among those connected by use of clock-asynchronous serial I/O devices.

The following are examples in which functions (a) to (e) are chosen:

| Transmission WITHOUT: other functions | P264 |
|---------------------------------------|------|
| Recention WITHOUT: other functions    | P268 |

# (5) Input/output to the serial I/O and the direction register

To input an external signal to the serial I/O, set the direction register of the relevant port to input. To output a signal from the serial I/O, set the direction register of the relevant port to output.

#### (6) Pins related to the serial I/O

• CLKo pins :Input pins for the transfer clock

RxD0, RxD1 pins
TxD0, TxD1 pins
:Input pins for data
:Output pins for data

#### (8) Registers related to the serial I/O

Figure 2.6.2 shows the memory map of serial I/O-related registers, and Figures 2.6.3 to 2.6.7 show UARTi-related registers.



Figure 2.6.2. Memory map of UARTi-related registers



Figure 2.6.3. UARTi-related registers (1)



Figure 2.6.4. UARTi-related registers (2)



Note 1: UART1 cannot be used in clock synchronous serial I/O.

Note 2: If you are using clock asynchronous serial I/O mode, you can enable 'receive enable bit' when RxD port input is "H". If RxD port input is "L" and you have enabled 'receive enable bit', then receive operation starts immediately.

#### UART transmit/receive control register 2

| b7 b6 b5 b4 b3 b2 b1 b0 |               | ymbol Addres<br>JCON 03B01                   |                                                                                                                      |                                                                                    |    |
|-------------------------|---------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|----|
|                         | Bit<br>symbol | Bit<br>name                                  | Function<br>(During clock synchronous<br>serial I/O mode)                                                            | Function<br>(During UART mode)                                                     | RW |
|                         | UOIRS         | UART0 transmit interrupt cause select bit    | 0 : Transmit buffer empty<br>(TI = 1)<br>1 : Transmission completed<br>(TXEPT = 1)                                   | 0 : Transmit buffer empty<br>(TI = 1)<br>1 : Transmission completed<br>(TXEPT = 1) | 00 |
|                         | U1IRS         | UART1 transmit interrupt cause select bit    | Set this bit to "0".                                                                                                 | 0 : Transmit buffer empty<br>(TI = 1)<br>1 : Transmission completed<br>(TXEPT = 1) | 00 |
|                         | UORRM         | UART0 continuous receive mode enable bit     | Continuous receive mode disabled     Continuous receive mode enable                                                  | Invalid                                                                            | 00 |
|                         | Set this      | bit to "0".                                  |                                                                                                                      |                                                                                    | 00 |
|                         | CLKMD0        | CLK/CLKS select bit 0                        | Valid when bit 5 = "1" 0 : Clock output to CLK1 1 : Clock output to CLKS1                                            | Invalid                                                                            | 00 |
|                         | CLKMD1        | CLK/CLKS select<br>bit 1 (Note 2)            | 0 : Normal mode<br>(CLK output is CLK0 only)<br>1 : Transfer clock output<br>from multiple pins<br>function selected | Must always be "0"                                                                 | 00 |
|                         |               | is assigned.<br>ite, set "0". When read, its | content is indeterminate.                                                                                            |                                                                                    |    |

Note 1: UART1 cannot be used in clock synchronous serial I/O.

Note 2: When using multiple pins to output the transfer clock, the following requirements must be met:

• UART0 internal/external clock select bit (bit 3 at address 03A016) = "0".

Figure 2.6.5. UARTi-related registers (3)



# 2.6.2 Operation of Serial I/O (transmission in UART mode)

In transmitting data in UART mode, choose functions from those listed in Table 2.6.4. Operations of the circled items are described below. Figure 2.6.6 shows the operation timing, and Figures 2.6.7 and 2.6.8 show the set-up procedures.

Table 2.6.4. Choosed functions

| Item                          |   | Set-up                              |  |  |
|-------------------------------|---|-------------------------------------|--|--|
| Transfer clock                | 0 | Internal clock (f1 / f8 / f32 / fc) |  |  |
| source                        |   | External clock (CLK0 pin) (Note)    |  |  |
| Transmission interrupt factor |   | Transmission buffer empty           |  |  |
|                               | 0 | Transmission complete               |  |  |
| Sleep mode                    | 0 | Sleep mode off                      |  |  |
|                               |   | Sleep mode selected                 |  |  |

Note: UART1 cannot be selected external clock.

Operation (1) Setting the transmit enable bit to "1" and writing transmission data to the UARTi transmit buffer register readies the data transmissible status.

- (2) Transmission data held in the UARTi transmit buffer register is transmitted to the UARTi transmit register. At this time, the first bit (the start bit) of the transmission data is transmitted from the TxDi pin. Then, data is transmitted, bit by bit, in sequence: LSB, ..., MSB, parity bit, and stop bit(s).
- (3) When the stop bit(s) is (are) transmitted, the transmit register empty flag goes to "1", which indicates that transmission is completed. At this time, the UARTi transmit interrupt request bit goes to "1". The transfer clock stops at "H" level.
- (4) If the transmission condition of the next data is ready when transmission is completed, a start bit is generated following to stop bit(s), and the next data is transmitted.



Figure 2.6.6. Operation timing of transmission in UART mode



Figure 2.6.7. Set-up procedure of transmission in UART mode (1)



Figure 2.6.8. Set-up procedure of transmission in UART mode (2)



# 2.6.3 Operation of Serial I/O (reception in UART mode)

In receiving data in UART mode, choose functions from those listed in Table 2.6.5. Operations of the circled items are described below. Figure 2.6.9 shows the operation timing, and Figures 2.6.10 and 2.6.11 show the set-up procedures.

Table 2.6.5. Choosed functions

| Item           |   | Set-up                              |  |  |  |
|----------------|---|-------------------------------------|--|--|--|
| Transfer clock |   | Internal clock (f1 / f8 / f32 / fc) |  |  |  |
| source         | 0 | External clock (CLK0 pin) (Note)    |  |  |  |
| Sleep mode     | 0 | Sleep mode off                      |  |  |  |
|                |   | Sleep mode selected                 |  |  |  |

Note: UART1 cannot be selected external clock.

Operation (1) Setting the receive enable bit to "1" readies data-receivable status.

- (2) When the first bit (the start bit) of reception data is received from the RxDi pin. Then, data is received, bit by bit, in sequence: LSB, ..., MSB, and stop bit(s).
- (3) When the stop bit(s) is (are) received, the content of the UARTi receive register is transmitted to the UARTi receive buffer register.
  - At this time, the receive complete flag goes to "1" to indicate that the reception is completed, the UARTi receive interrupt request bit goes to "1".
- (4) The receive complete flag goes to "0" when the lower-order byte of the UARTi buffer register is read.



Figure 2.6.9. Operation timing of reception in UART mode



Figure 2.6.10. Set-up procedure of reception in UART mode (1)



Figure 2.6.11. Set-up procedure of reception in UART mode (2)



#### 2.7 A-D Converter

#### 2.7.1 Overview

The A-D converter used in the M16C/60 group operates on a successive conversion basis. The following is an overview of the A-D converter.

#### (1) Mode

The A-D converter operates in one of five modes:

#### (a) One-shot mode

Carries out A-D conversion on input level of one specified pin only once.

#### (b) Repetition mode

Repeatedly carries out A-D conversion on input level of one specified pin.

#### (c) Single sweep mode

Carries out A-D conversion on input level of two or more specified pins only once.

#### (d) Repeated sweep mode 0

Repeatedly carries out A-D conversion on input level of two or more pins.

#### (e) Repeated sweep mode 1

Repeatedly carries out A-D conversion on input level of two or more pins. This mode is different from the repeated sweep mode 0 in that weights can be assigned to specifing pins control the number of conversion times.

#### (2) Operation clock

The operation clock in 5 V operation can be selected from the following: fAD, divide-by-2 fAD, and divide-by-4 fAD. In 3 V operation, the selection is divide-by-2 fAD or divide-by-4. The fAD frequency is equal to that of the CPU's main clock.

#### (3) Conversion time

Number of conversion for A-D convertor varies depending on resolution as given. Table 2.7.1 shows relation between the A-D converter operation clock and conversion time.

Sample & Hold function selected:

33 cycles for 10-bit resolution, or 28 cycles for 8-bit resolution

No Sample & Hold function:

59 cycles for 10-bit resolution, or 49 cycles for 8-bit resolution

Table 2.7.1. Conversion time every operation clock

| Frequency selection             | n bit 1     |                                                          | 1         |           |
|---------------------------------|-------------|----------------------------------------------------------|-----------|-----------|
| Frequency selection             | n bit 0     | 0                                                        | 0 1       |           |
| A-D converter's operation clock |             | $\phi AD = \frac{fAD}{4} \qquad \phi AD = \frac{fAD}{2}$ |           | φAD = fAD |
| Min. conversion                 | 8-bit mode  | 28 X                                                     | ( φAD     |           |
| cycles (Note 1)                 | 10-bit mode | 33 ×                                                     | <br>( φad |           |
| Min. conversion time (Note 2)   | 8-bit mode  | 11.2µs                                                   | 5.6µs     | 2.8µs     |
|                                 | 10-bit mode | 13.2µs                                                   | 6.6µs     | 3.3µs     |

Note 1: The number of conversion cycles per one analog input pin.

Note 2: The conversion time per one analog input pin (when fAD = f(XIN) = 10 MHz)

# (4) Functions selection

#### (a) Sample & Hold function

Sample & Hold function samples input voltage when A-D conversion starts and carries out A-D conversion on the voltage sampled. When A-D conversion starts, input voltage is sampled for 3 cycles of the operation clock. When the Sample & Hold function is selected, set the operation clock for A-D conversion to 1 MHz or higher.

#### (b) 8-bit A-D to 10-bit A-D switching function

Either 8-bit resolution or 10-bit resolution can be selected. When 8-bit resolution is selected, the 8 higher-order bits of the 10-bit A-D are subjected to A-D conversion. The equations for 10-bit resolution and 8-bit resolution are given below:

10-bit resolution (Vref X n / 
$$2^{10}$$
) – (Vref X 0.5 /  $10^{10}$ ) (n = 1 to 1023), 0 (n = 0)

8-bit resolution (Vref X n / 
$$2^8$$
) – (Vref X 0.5 /  $2^{10}$ ) (n = 1 to 256), 0 (n = 0)

#### (c) Analog input group function

The analog input pins can be switched between the port P6 group (ANo to AN4) and the port P5 group (AN50 to AN54).

#### (d) Connecting or cutting Vref

Cutting Vref allows decrease of the current flowing into the A-D converter. To decrease the microcomputer's power consumption, cut Vref. To carry out A-D conversion, start A-D conversion 1 µs or longer after connecting Vref.

The following are exsamples in which functions (a) through (d) are selected:

| One-shot mode         | P278 |
|-----------------------|------|
| Repeat mode           | P280 |
| Single sweep mode     | P282 |
| Repeated sweep mode 0 | P284 |
| Repeated sweep mode 1 | P286 |

#### (5) Input to A-D converter and direction register

To use the A-D converter, set the direction register of the relevant port to input.

#### (6) Pins related to A-D converter

| (a) AN0 pin through AN7 pin   | Input pins of the A-D converter (Port P6 group)  |
|-------------------------------|--------------------------------------------------|
| (b) AN50 pin through AN57 pin | Input pins of the A-D converter (Port P5 group ) |
| (c) AVcc pin                  | Power source pin of the analog section           |
| (d) VREF pin                  | Input pin of reference voltage                   |
| (e) AVss pin                  | GND pin of the analog section                    |



# (7) A-D converter and related registers

Figure 2.7.1 shows the memory map of A-D converter-related registers, and Figures 2.7.2 through 2.7.4 show A-D converter-related registers.



Figure 2.7.1. Memory map of A-D converter-related registers



Figure 2.7.2. A-D converter-related registers (1)



Figure 2.7.3. A-D converter-related registers (2)



Figure 2.7.4. A-D converter-related registers (3)



## 2.7.2 Operation of A-D converter (one-shot mode)

In one-shot mode, choose functions from those listed in Table 2.7.2. Operations of the circled items are described below. Figure 2.7.5 shows the operation timing, and Figure 2.7.6 shows the set-up procedure.

Table 2.7.2. Choosed functions

| Item                       |   | Set-up                                    |
|----------------------------|---|-------------------------------------------|
| Operation clock \$\phiAD\$ | 0 | Divided-by-4 fad / divided-by-2 fad / fad |
| Resolution                 | 0 | 8-bit / 10-bit                            |
| Analog input pin           | 0 | One of ANo pin to AN7 pin (Note)          |
| Sample & Hold              |   | Not activated                             |
|                            | 0 | Activated                                 |

Note: When the port P5 group is selected, analog input pins are changed from ANo to AN4 to pins AN50 to AN54.

- Operation (1) Setting the A-D conversion start flag to "1" causes the A-D converter to begin operating.
  - (2) After A-D conversion is completed, the content of the successive comparison register (conversion result) is transmitted to A-D register i. At this time, the A-D conversion interrupt request bit goes to "1". Also, the A-D conversion start flag goes to "0", and the A-D converter stops operating.



Figure 2.7.5. Operation timing of one-shot mode



Figure 2.7.6. Set-up procedure of one-shot mode



## 2.7.3 Operation of A-D Converter (in repeat mode)

In repeat mode, choose functions from those listed in Table 2.7.3. Operations of the circled items are described below. Figure 2.7.7 shows timing chart, and Figure 2.7.8 shows the set-up procedure.

Table 2.7.3. Choosed functions

| Item                     | Set-up |                                                          |
|--------------------------|--------|----------------------------------------------------------|
| Operation clock \$\phiAD | 0      | Divided-by-4 fad / divided-by-2 fad / fad                |
| Resolution               | 0      | 8-bit / 10-bit                                           |
| Analog input pin         | 0      | One of AN <sub>0</sub> pin to AN <sub>7</sub> pin (Note) |
| Sample & Hold            |        | Not activated                                            |
|                          | 0      | Activated                                                |

Note: When the port P5 group is selected, analog input pins are changed from ANo to AN4 to pins AN50 to AN54.

# Operation (1) Setting the A-D conversion start flag to "1" causes the A-D converter to start operating.

- (2) After the first conversion is completed, the content of the successive comparison register (conversion result) is transmitted to A-D register i. The A-D conversion interrupt request bit does not go to "1".
- (3) The A-D converter continues operating until the A-D conversion start flag is set to "0" by software. The conversion result is transmitted to A-D register i every time a conversion is completed.



Figure 2.7.7. Operation timing of repeat mode



Figure 2.7.8. Set-up procedure of repeat mode



## 2.7.4 Operation of A-D Converter (in single sweep mode)

In single sweep mode, choose functions from those listed in Table 2.7.4. Operations of the circled items are described below. Figure 2.7.9 shows timing chart, and Figure 2.7.10 shows the set-up procedure.

Table 2.7.4. Choosed functions

| Item                       |   | Set-up                                                                                        |  |  |
|----------------------------|---|-----------------------------------------------------------------------------------------------|--|--|
| Operation clock \$\phiAD\$ | 0 | Divided-by-4 fAD / divided-by-2 fAD / fAD                                                     |  |  |
| Resolution                 | 0 | 8-bit / 10-bit                                                                                |  |  |
| Analog input pin           | 0 | ANo and AN1 (2 pins) / ANo to AN3 (4 pins) / ANo to AN5 (6 pins) / ANo to AN7 (8 pins) (Note) |  |  |
| Sample & Hold              |   | Not activated                                                                                 |  |  |
|                            | 0 | Activated                                                                                     |  |  |

Note: When the port P5 group is selected, analog input pins are changed from ANo to AN4 to pins AN50 to AN54.

- Operation (1) Setting the A-D conversion start flag to "1" causes the A-D converter to start the conversion on voltage input to the ANo/AN50 pin.
  - (2) After the A-D conversion of voltage input to the ANo/AN50 pin is completed, the content of the successive comparison register (conversion result) is transmitted to A-D register 0. The A-D converter converts all analog input pins selected by the user. The conversion result is transmitted to A-D register i corresponding to each pin, every time conversion on one pin is completed.
  - (3) When the A-D conversion on all the analog input pins selected is completed, the A-D conversion interrupt request bit goes to "1". At this time, the A-D conversion start flag goes to "0". The A-D converter stops operating.



Figure 2.7.9. Operation timing of single sweep mode



Figure 2.7.10. Set-up procedure of single sweep mode



## 2.7.5 Operation of A-D Converter (in repeat sweep mode 0)

In repeat sweep 0 mode, choose functions from those listed in Table 2.7.5. Operations of the circled items are described below. Figure 2.7.11 shows timing chart, and Figure 2.7.12 shows the set-up procedure.

Table 2.7.5. Choosed functions

| Item                       |   | Set-up                                                                                        |  |  |
|----------------------------|---|-----------------------------------------------------------------------------------------------|--|--|
| Operation clock \$\phiAD\$ | 0 | Divided-by-4 fAD / divided-by-2 fAD / fAD                                                     |  |  |
| Resolution                 | 0 | 8-bit / 10-bit                                                                                |  |  |
| Analog input pin           | 0 | ANo and AN1 (2 pins) / ANo to AN3 (4 pins) / ANo to AN5 (6 pins) / ANo to AN7 (8 pins) (Note) |  |  |
| Sample & Hold              |   | Not activated                                                                                 |  |  |
|                            | 0 | Activated                                                                                     |  |  |

Note: When the port P5 group is selected, analog input pins are changed from ANo to AN4 to pins AN50 to AN54.

Operation (1) Setting the A-D conversion start flag to "1" causes the A-D converter to start the conversion on voltage input to the ANo/AN50 pin.

- (2) After the A-D conversion of voltage input to the ANo/AN50 pin is completed, the content of the successive comparison register (conversion result) is transmitted to A-D register 0.
- (3) The A-D converter converts all pins selected by the user. The conversion result is transmitted to A-D register i corresponding to each pin every time A-D conversion on the pin is completed. The A-D conversion interrupt request bit does not go to "1".
- (4) The A-D converter continues operating until the A-D conversion start flag is set to "0" by software.



Figure 2.7.11. Operation timing of repeat sweep 0 mode



Figure 2.7.12. Set-up procedure of repeat sweep 0 mode



## 2.7.6 Operation of A-D Converter (in repeat sweep mode 1)

In repeat sweep 1 mode, choose functions from those listed in Table 2.7.6. Operations of the circled items are described below. Figure 2.7.13 shows ANi pin's sweep sequence, Figure 2.7.14 shows timing chart, and Figure 2.7.15 shows the set-up procedure.

Table 2.7.6. Choosed functions

| Item                       | Set-up |                                                                                       |
|----------------------------|--------|---------------------------------------------------------------------------------------|
| Operation clock \$\phiAD\$ | 0      | Divided-by-4 fAD / divided-by-2 fAD / fAD                                             |
| Resolution                 | 0      | 8-bit / 10-bit                                                                        |
| Analog input pin           | 0      | ANo (1 pins) / ANo to AN1 (2 pins) / ANo to AN2 (3 pins) / ANo to AN3 (4 pins) (Note) |
| Sample & Hold              |        | Not activated                                                                         |
|                            | 0      | Activated                                                                             |

Note: When the port P5 group is selected, analog input pins are changed from ANo to AN4 to pins AN50 to AN54.

Operation

- (1) Setting the A-D conversion start flag to "1" causes the A-D converter to start the conversion on voltage input to the ANo/AN50 pin.
- (2) After the A-D conversion on voltage input to the ANo/AN50 pin is completed, the content of the successive comparison register (conversion result) is transmitted to A-D register 0.
- (3) Every time the A-D converter carries out A-D conversion on a selected analog input pin, the A-D converter carries out A-D conversion on only one unselected pin, and then the A-D converter carries out A-D conversion from the AN0 pin again. (See Figure 2.7.13.) The conversion result is transmitted to A-D register i every time conversion on a pin is completed. The A-D conversion interrupt request bit does not go to "1".
- (4) The A-D converter continues operating until software goes the A-D conversion start flag to "0".



Figure 2.7.13. ANi pin's sweep sequence in repeat sweep mode



Figure 2.7.14. Operation timing of repeat sweep 1 mode



Figure 2.7.15. Set-up procedure of repeat sweep 1 mode

#### 2.7. 7 Precautions for A-D Converter

- (1) Write to each bit (except bit 6) of A-D control register 0, to each bit of A-D control register 1, and to bit 0 of A-D control register 2 when A-D conversion is stopped (before a trigger occurs). In particular, when the Vref connection bit is changed from 0 to 1, start A-D conversion after an elapse of 1 ms or longer.
- (2) To reduce conversion error due to noise, connect a voltage to the AVcc pin and to the Vref pin from an independent source. It is recommended to connect a capacitor between the AVss pin and the AVcc pin, between the AVss pin and the Vref pin, and between the AVss pin and the analog input pin (ANi/ANsi). Figure 2.7.16 shows the an example of connecting the capacitors to these pins.



Figure 2.7.16. Use of capacitors to reduce noice

- (3) Set the direction register of the following ports to input: the port corresponding to a pin to be used as an analog input pin and external trigger input pin.
- (4) If using the A-D converter with Vcc = 2.7V to 4.0 V: Use without fAD (no frequency division) for  $\phi$ AD. Select without the Sample & Hold feature. Select 8-bit mode.
- (5) Rewrite to analog input pin after changing A-D operation mode. The two cannot be set at the same time.
- (6) When using the one-shot or single sweep mode Confirm that A-D conversion is complete before reading the A-D register. (Note: When A-D conversion interrupt request bit is set, it shows that A-D conversion is completed.)
- (7) When using the repeat mode or repeat sweep mode 0 or 1
  Use the undivided main clock as the internal CPU clock.

## 2.7.8 Method of A-D Conversion (10-bit mode)

- (1) The A-D converter compares the reference voltage (Vref) generated internally based on the contents of the successive comparison register with the analog input voltage (VIN) input from the analog input pin. Each bit of the comparison result is stored in the successive comparison register until analog-to-digital conversion (successive comparison method) is complete. If a trigger occurs, the A-D converter carries out the following:
  - 1. Fixes bit 9 of the successive comparison register.

Compares Vref with Vin: [In this instance, the contents of the successive comparison register are "10000000002" (default).]

Bit 9 of the successive comparison register varies depending on the comparison result as follows.

If Vref < VIN, then "1" is assigned to bit 9.

If Vref > VIN, then "0" is assigned to bit 9.

2. Fixes bit 8 of the successive comparison register.

Sets bit 8 of the successive comparison register to "1", then compares Vref with VIN. Bit 8 of the successive comparison register varies depending on the comparison result as follows:

If Vref < VIN, then "1" is assigned to bit 8.

If Vref > VIN, then "0" is assigned to bit 8.

3. Fixes bit 7 through bit 0 of the successive comparison register.

Carries out step 2 above on bit 7 through bit 0.

After bit 0 is fixed, the contents of the successive comparison register (conversion result) are transmitted to A-D register i.

Vref is generated based on the latest content of the successive comparison register. Table 2.7.7 shows the relationship of the successive comparison register contents and Vref. Table 2.7.8 shows how the successive comparison register and Vref vary while A-D conversion is in progress. Figure 2.7.17 shows theoretical A-D conversion characteristics.

Table 2.7.7. Relationship of the successive comparison register contents and Vref

| Successive approximation register : n | Vref (V)                                                                    |  |  |
|---------------------------------------|-----------------------------------------------------------------------------|--|--|
| 0                                     | 0                                                                           |  |  |
| 1 to1023                              | $\frac{\text{VREF}}{1024}  \text{x}  \text{n}  -  \frac{\text{VREF}}{2048}$ |  |  |

Table 2.7.8. Variation of the successive comparison register and Vref while A-D conversion is in progress (10-bit mode)

|                            | Successive approximation register              | Vref change                                                                                                                                                                                                                             |
|----------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A-D converter stopped      | b9 b0<br>1 0 0 0 0 0 0 0 0 0                   | VREF [V]                                                                                                                                                                                                                                |
| 1st comparison             | 1 0 0 0 0 0 0 0 0 0                            | $\frac{\text{VREF}}{2} - \frac{\text{VREF}}{2048} \text{ [V]}$                                                                                                                                                                          |
| very 2nd comparison very 4 | n9 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0       | $\frac{\text{VREF}}{2} \pm \frac{\text{VREF}}{4} - \frac{\text{VREF}}{2048} \text{ [V]} \begin{pmatrix} \text{ng} = 1 & + & \frac{\text{VREF}}{4} \\ \text{ng} = 0 & - & \frac{\text{VREF}}{4} \end{pmatrix}$                           |
| 3rd comparison             | n9 n8 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0    | $\frac{\text{VREF}}{2} \pm \frac{\text{VREF}}{4} \pm \frac{\text{VREF}}{8} - \frac{\text{VREF}}{2048} \text{ [V]} \begin{pmatrix} \text{ns} = 1 & + & \frac{\text{VREF}}{8} \\ \text{ns} = 0 & - & \frac{\text{VREF}}{8} \end{pmatrix}$ |
|                            |                                                |                                                                                                                                                                                                                                         |
| ↓<br>10th comparison<br>⊥  | n9   n8   n7   n6   n5   n4   n3   n2   n1   0 | $\frac{\text{VREF}}{2} \pm \frac{\text{VREF}}{4} \pm \frac{\text{VREF}}{8} \pm \dots \pm \frac{\text{VREF}}{1024} - \frac{\text{VREF}}{2048} \text{ [V]}$                                                                               |
| Conversion complete        | This data transfers to the bit 0               |                                                                                                                                                                                                                                         |
| Conversion complete        |                                                |                                                                                                                                                                                                                                         |



Figure 2.7.17. Theoretical A-D conversion characteristics (10-bit mode)

## 2.7.9 Method of A-D Conversion (8-bit mode)

(1) In 8-bit mode, 8 higher-order bits of the 10-bit successive comparison register becomes A-D conversion result. Hence, if compared to a result obtained by using an 8-bit A-D converter, the voltage compared is different by 3 VREF/2048 (see what are underscored in Table 2.7.9), and differences in stepping points of output codes occur as shown in Figure 2.7.18.

Table 2.7.9. The comparison voltage in 8-bit mode compared to 8-bit A-D converter

|                               |              | 8-bit mode                                                         | 8-bit A-D converter                                                                      |  |
|-------------------------------|--------------|--------------------------------------------------------------------|------------------------------------------------------------------------------------------|--|
|                               | n = 0        | 0                                                                  | 0                                                                                        |  |
| Comparison<br>voltage<br>Vref | n = 1 to 255 | $\frac{\text{VREF}}{2^8}$ x n - $\frac{\text{VREF}}{2^{10}}$ x 0.5 | $\frac{\text{VREF}}{2^8}  \text{x}  \text{n}  -  \frac{\text{VREF}}{2^8}  \text{x}  0.5$ |  |



Figure 2.7.18. The level conversion characteristics of 8-bit mode and 8-bit A-D converter

Table 2.7.10. Variation of the successive comparison register and Vref while A-D conversion is in progress (8-bit mode)

|                                                                       | Successive approximation register                                                                               | Vref change                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A-D converter stopped  1st comparison  2nd comparison  3rd comparison | b9 b0  1 0 0 0 0 0 0 0 0 0 0 0  1 0 0 0 0 0                                                                     | $ \frac{V_{REF}}{2} [V] $ $ \frac{V_{REF}}{2} - \frac{V_{REF}}{2048} [V] $ $ \frac{V_{REF}}{2} \pm \frac{V_{REF}}{4} - \frac{V_{REF}}{2048} [V] \begin{pmatrix} n_{9} = 1 & + \frac{V_{REF}}{4} \\ n_{9} = 0 & - \frac{V_{REF}}{4} \end{pmatrix} $ $ \frac{V_{REF}}{2} \pm \frac{V_{REF}}{4} \pm \frac{V_{REF}}{8} - \frac{V_{REF}}{2048} [V] \begin{pmatrix} n_{8} = 1 & + \frac{V_{REF}}{8} \\ n_{8} = 0 & - \frac{V_{REF}}{8} \end{pmatrix} $ $ \vdots $ |
| 8th comparison  Conversion complete                                   | n9 n8 n7 n6 n5 n4 n3 1 0 0  n9 n8 n7 n6 n5 n4 n3 n2 0 0  This data transfers to bit 0 to bit 7 of A-D register. | $\frac{\text{VREF}}{2} \pm \frac{\text{VREF}}{4} \pm \frac{\text{VREF}}{8} \pm \dots \pm \frac{\text{VREF}}{256} - \frac{\text{VREF}}{2048} \text{ [V]}$                                                                                                                                                                                                                                                                                                    |



Figure 2.7.19. Theoretical A-D conversion characteristics (8-bit mode)



## 2.7.10 Absolute Accuracy and Differential Non-Linearity Error

#### Absolute accuracy

Absolute accuracy is the difference between output code based on the theoretical A-D conversion characteristics, and actual A-D conversion result. When measuring absolute accuracy, the voltage at the middle point of the width of analog input voltage (1-LSB width), that can meet the expectation of outputting an equal code based on the theoretical A-D conversion characteristics, is used as an analog input voltage. For example, if 10-bit resolution is used and if VREF (reference voltage) = 5.12 V, then 1-LSB width becomes 5 mV, and 0 mV, 5 mV, 10 mV, 15 mV, 20 mV, .... are used as analog input voltages. If analog input voltage is 25 mV, "absolute accuracy = – 3LSB" refers to the fact that actual A-D conversion falls on a range from "00216" to "00816" though an output code, "00516", can be expected from the theoretical A-D conversion characteristics. Zero error and full-scale error are included in absolute accuracy.

Also, all the output codes for analog input voltage between VREF and AVcc becomes "3FF16".



Figure 2.7.20. Absolute accuracy (10-bit resolution)

### • Differential non-linearity error

Differential non-linearity error refers to the difference between 1-LSB width based on the theoretical A-D conversion characteristics (an analog input width that can meet the expectation of outputting an equal code) and an actually measured 1-LSB width (analog input voltage width that outputs an equal code). If 10-bit resolution is used and if VREF (reference voltage) = 5.12 V, "differential non-linearity error = -1LSB" refers to the fact that 1-LSB width actually measured falls on a range from 0 mV to 10 mV though 1-LSB width based on the theoretical A-D conversion characteristics is 5 mV (see 5.2 A-D converter's standard characteristics).



Figure 2.7.21. Differential non-linearity error (10-bit resolution)

# 2.7.11 Internal Equivalent Circuit of Analog Input

Figure 2.7.22 shows the internal equivalent circuit of analog input.



Figure 2.7.22. Internal equivalent circuit to analog input

## 2.7.12 Sensor's Output Impedance under A-D Conversion

To carry out A-D conversion properly, charging the internal capacitor C shown in Figure 2.7.23 has to be completed within a specified period of time. With T as the specified time, time T is the time that switches SW2 and SW3 are connected to O in Figure 2.7.22. Let output impedance of sensor equivalent circuit be R0, microcomputer's internal resistance be R, precision (error) of the A-D converter be X, and the A-D converter's resolution be Y (Y is 1024 in the 10-bit mode, and 256 in the 8-bit mode).

Vc is generally Vc = VIN 
$$\{1 - e^{-\frac{t}{C(R0 + R)}}\}$$
  
And when t = T,  $Vc=VIN - \frac{X}{Y}VIN=VIN(1 - \frac{X}{Y})$   

$$e^{-\frac{T}{C(R0 + R)}} = \frac{X}{Y}$$

$$-\frac{T}{C(R0 + R)} = In \frac{X}{Y}$$
Hence,  $R0 = -\frac{T}{C \cdot In \frac{X}{Y}}$ 

With the model shown in Figure 2.7.29 as an example, when the difference between VIN and VC becomes 0.1LSB, we find impedance R0 when voltage between pins VC changes from 0 to VIN-(0.1/1024) VIN in time T. (0.1/1024) means that A-D precision drop due to insufficient capacitor charge is held to 0.1LSB at time of A-D conversion in the 10-bit mode. Actual error however is the value of absolute precision added to 0.1LSB. When f(XIN) = 10 MHz, T = 0.3 us in the A-D conversion mode with sample & hold. Output impedance R0 for sufficiently charging capacitor C within time T is determined as follows.

$$T = 0.3 \text{ ms}, R = 7.8 \text{ kW}, C = 3 \text{ pF}, X = 0.1, and Y = 1024$$
. Hence,

R0 = 
$$-\frac{0.3 \times 10^{-6}}{3.0 \times 10^{-12} \cdot \ln \frac{0.1}{1024}}$$
 -7.8 ×10<sup>3</sup> ÷ 3.0 × 10<sup>3</sup>

Thus, the allowable output impedance of the sensor circuit capable of thoroughly driving the A-D converter turns out to be approximately 3.0 kw. Tables 2.7.11 and 2.7.12 show output impedance values based on the LSB values.



Figure 2.7.23 A circuit equivalent to the A-D conversion terminal



Tables 2.7.11. Output impedance values based on the LSB values (1)

| f(Xin) | Cycle | T             | Ri + Rf | С    | Resolution | R0max  |
|--------|-------|---------------|---------|------|------------|--------|
| (MHz)  | (ns)  |               | (kohm)  | (pF) | (LSB)      | (kohm) |
| 10     | 0.1   | 0.3           | 7.8     | 3.0  | 0.1        | 3.0    |
|        |       | (3 x cycle,   |         |      | 0.3        | 4.5    |
|        |       | Sample & hold |         |      | 0.5        | 5.3    |
|        |       | bit is        |         |      | 0.7        | 5.9    |
|        |       | enabled       |         |      | 0.9        | 6.4    |
|        |       |               |         |      | 1.1        | 6.8    |
|        |       |               |         |      | 1.3        | 7.2    |
|        |       |               |         |      | 1.5        | 7.5    |
|        |       |               |         |      | 1.7        | 7.8    |
|        |       |               |         |      | 1.9        | 8.1    |
| 10     | 0.1   | 0.2           | 7.8     | 3.0  | 0.1        | -0.6   |
|        |       | (2 x cycle,   |         |      | 0.3        | 0.4    |
|        |       | Sample & hold |         |      | 0.5        | 0.9    |
|        |       | bit is        |         |      | 0.7        | 1.3    |
|        |       | disabled      |         |      | 0.9        | 1.7    |
|        |       |               |         |      | 1.1        | 2.0    |
|        |       |               |         |      | 1.3        | 2.2    |
|        |       |               |         |      | 1.5        | 2.4    |
|        |       |               |         |      | 1.7        | 2.6    |
|        |       |               |         |      | 1.9        | 2.8    |

Tables 2.7.12. Output impedance values based on the LSB values (2)

| f(Xin) | Cycle | Т             | Ri + Rf | С    | Resolution | R0max  |
|--------|-------|---------------|---------|------|------------|--------|
| (MHz)  | (ns)  |               | (kohm)  | (pF) | (LSB)      | (kohm) |
| 10     | 0.1   | 0.3           | 7.8     | 3.0  | 0.1        | 4.9    |
|        |       | (3 x cycle,   |         |      | 0.3        | 7.0    |
|        |       | Sample & hold |         |      | 0.5        | 8.2    |
|        |       | bit is        |         |      | 0.7        | 9.1    |
|        |       | enabled       |         |      | 0.9        | 9.9    |
|        |       |               |         |      | 1.1        | 10.5   |
|        |       |               |         |      | 1.3        | 11.1   |
|        |       |               |         |      | 1.5        | 11.7   |
|        |       |               |         |      | 1.7        | 12.1   |
|        |       |               |         |      | 1.9        | 12.6   |
| 10     | 0.1   | 0.2           | 7.8     | 3.0  | 0.1        | 0.7    |
|        |       | (2 x cycle,   |         |      | 0.3        | 2.1    |
|        |       | Sample & hold |         |      | 0.5        | 2.9    |
|        |       | bit is        |         |      | 0.7        | 3.5    |
|        |       | disabled      |         |      | 0.9        | 4.0    |
|        |       |               |         |      | 1.1        | 4.4    |
|        |       |               |         |      | 1.3        | 4.8    |
|        |       |               |         |      | 1.5        | 5.2    |
|        |       |               |         |      | 1.7        | 5.5    |
|        |       |               |         |      | 1.9        | 5.8    |

## 2.8 Watchdog Timer

#### 2.8.1 Overview

The watchdog timer can detect a runaway program using its 15-bit timer prescaler. The following is an overview of the watchdog timer.

#### (1) Watchdog timer start procedure

When reset, the watchdog timer is in stopped state. Writing to the watchdog timer start register initializes the watchdog timer to 7FFF16 and causes it to start performing a down count. The watchdog timer, once started operating, cannot be stopped by any means other than stopping conditions.

### (2) Watchdog timer stop conditions

The watchdog timer stops in any one of the following states:

- (a) Period in which the CPU is in stopped state
- (b) Period in which the CPU is in waiting state

#### (3) Watchdog timer initialization

The watchdog timer is initialized to 7FFF16 in the cases given below, and begins a down count.

- (a) When the watchdog timer writes to the watchdog timer start register while a count is in progress
- (b) When the watchdog timer underflows

#### (4) Runaway detection

When the watchdog timer underflows, a watchdog timer interrupt occurs. In writing a program, write to the watchdog timer start register before the watchdog timer underflows. The watchdog timer interrupt occurs regardless of the status of the interrupt enable flag (I flag). In processing a watchdog timer interrupt, set the software reset bit to "1" to reset software.

#### (5) Watchdog timer cycle

The watchdog timer cycle varies depending on the BCLK and the frequency division ratio of the prescaler selected.

Table 2.8.1. The watchdog timer cycle

| CM07 | CM06    | CM17      | CM16    | BCLK         | WDC7    | Period                 |
|------|---------|-----------|---------|--------------|---------|------------------------|
| 0    | 0       | 0         | 0       | 10MHz        | 0       | Approx. 52.4ms (Note)  |
|      | 0       | U         | U       | TOWINZ       | 1       | Approx. 419.2ms (Note) |
| 0    | 0       | 0         | 1       | 5MHz         | 0       | Approx. 104.9ms (Note) |
|      |         | 0         | ı       | SIVII IZ     | 1       | Approx. 838.8ms (Note) |
| 0    | 0       | 0 1       | 0       | 2.5MHz       | 0       | Approx. 209.7ms (Note) |
|      | 0       |           |         |              | 1       | Approx. 1.68s (Note)   |
| 0    | 0       | 0 1       | 1       | 0.625MHz     | 0       | Approx. 838.8ms (Note) |
|      | 0       | '         | '       | 0.0251011 12 | 1       | Approx. 6.71s (Note)   |
|      | 4       | 1 Invalid | Invalid | 4.058411-    | 0       | Approx. 419.2ms (Note) |
| 0    | 1       |           |         | 1.25MHz      | 1       | Approx. 3.35s (Note)   |
| 1    | Invalid | Invalid   | Invalid | 32kHz        | Invalid | Approx. 2s (Note)      |

Note: An error due to the prescaler occurs.

### (6) Registers related to the watchdog timer

Figure 2.8.1 shows the memory map of watchdog timer-related registers, and Figure 2.8.2 shows watchdog timer-related registers.



Figure 2.8.1. Memory map of watchdog timer-related registers



Figure 2.8.2. Watchdog timer-related registers

## 2.8.2 Operation of Watchdog Timer

The following is an operation of the watchdog timer. Figure 2.8.3 shows the operation timing, and Figure 2.8.4 shows the set-up procedure.

Operation (1) Writing to the watchdog timer start register initializes the watchdog timer to 7FFF16 and causes it to start a down count.

- (2) With a count in progress, writing to the watchdog timer start register again initializes the watchdog timer to 7FFF16 and causes it to resume counting.
- (3) Either executing the WAIT instruction or going to the stopped state causes the watchdog timer to hold the count in progress and to stop counting. The watchdog timer resumes counting after returning from the execution of the WAIT instruction or from the stopped state.
- (4) If the watchdog timer underflows, it is initialized to 7FFF16 and continues counting. At this time, a watchdog timer interrupt occurs.



Figure 2.8.3. Operation timing of watchdog timer



Figure 2.8.4. Set-up procedure of watchdog timer

## 2.9 Address Match Interrupt

#### 2.9.1 Overview

The address match interrupt is used for correcting a ROM or for a simplified debugging-purpose monitor. The following is an overview of the address match interrupt.

#### (1) Enabling/disabling the address match interrupt

The address match interrupt enable bit can be used to enable and disable an address match interrupt. It is affected neither by the processor interrupt priority level (IPL) nor the interrupt enable flag (I flag).

## (2) Timing of the address match interrupt

An interrupt occurs immediately before executing the instruction in the address indicated by the address match interrupt register. Set the first address of the instruction in the address match interrupt register. Setting a half address of an instruction or an address of tabulated data does not generate an address match interrupt.

The first instruction of an interrupt routine does not generate an address match interrupt either.

#### (3) Returning from an address match interrupt

The return address put in the stack when an address match interrupt occurs depends on the instruction not yet executed (the instruction the address match interrupt register indicates). The return address is not put in the stack. For this reason, to return from an address match interrupt, either rewrite the content of the stack and use the REIT instruction or use the POP instruction to restore the stack to the state as it was before the interrupt occurred and return by use of a jump instruction.

Figure 2.9.1 shows unexecuted instructions and corresponding the stacked addresses.

<Instructions whose address is added to by 2 when an address match interrupt occurs>

- 16-bit operation code instructions
- 8-bit operation code instructions given below

| ADD.B:S  | #IMM8,dest                        | SUB.B:S  | #IMM8,dest         | AND.B:S | #IMM8,dest |
|----------|-----------------------------------|----------|--------------------|---------|------------|
| OR.B:S   | #IMM8,dest                        | MOV.B:S  | #IMM8,dest         | STZ.B:S | #IMM8,dest |
| STNZ.B:S | #IMM8,dest                        | STZX.B:S | #IMM81,#IMM82,dest |         |            |
| CMP.B:S  | #IMM8,dest                        | PUSHM    | src                | POPM    | dest       |
| JMPS     | #IMM8                             | JSRS     | #IMM8              |         |            |
| MOV.B:S  | #IMM,dest (However, dest = A0/A1) |          |                    |         |            |

<Instructions whose address is added to by 1 when an address match interrupt occurs>

• Instructions other than those listed above

Figure 2.9.1. Unexecuted instructions and corresponding stacked addresses

#### (4) How to determine an address match interrupt

Address match interrupts can be set at two different locations. However, both location will have the same vector address. Therefore, it is necessary to determine which interrupt has occurred; address match interrupt 0 or address match interrupt 1. Using the content of the stack, etc., determine which interrupt has occurred according to the first part of the address match interrupt routine.

### (5) Registers related to the address match interrupt

Figure 2.9.2 shows the memory map of address match interrupt-related registers, and Figure 2.9.3 shows address match interrupt-related registers.



Figure 2.9.2. Memory map of address match interrupt-related registers



Figure 2.9.3. Address match interrupt-related registers

## 2.9.2 Operation of Address Match Interrupt

The following is an operation of address match interrupt. Figure 2.9.4 shows the set-up procedure of address match interrupt, and Figure 2.9.5 shows the overview of the address match interrupt handling routine.

- Operation (1) The address match interrupt handling routine sets an address to be used to cause the address match interrupt register to generate an interrupt.
  - (2) Setting the address match enable flag to "1" enables an interrupt to occur.
  - (3) An address match interrupt occurs immediately before the instruction in the address indicated by the address match interrupt register as a program is executed.



Figure 2.9.4. Set-up procedure of address match interrupt



Figure 2.9.5. Overview of the address match interrupt handling routine

## 2.10 Key-Input Interrupt

#### 2.10.1 Overview

Key-input interrupt occurs when a falling edge is input to P00 through P07. The following is an overview of the key-input interrupt:

#### (1) Enabling/disabling the key-input interrupt

The key-input interrupt can be enabled and disabled using the key-input interrupt register. The key-input interrupt is affected by the interrupt priority level (IPL) and the interrupt enable flag (I flag).

#### (2) Occurrence timing of the key-input interrupt

With key-input interrupt acceptance enabled, pins P0o through P07, which are set to input, become key-input interrupt pins ( $\overline{\text{KI0}}$  through  $\overline{\text{KI7}}$ ). A key-input interrupt occurs when a falling edge is input to a key-input interrupt pin. At this moment, the level of other key-input interrupt pins must be "H". No interrupt occurs when the level of other key-input interrupt pins is "L".

#### (3) How to determine a key-input interrupt

A key-input interrupt occurs when a falling edge is input to one of eight pins, but each pin has the same vector address.

Therefore, read the input level of pins P00 through P07 in the key-input interrupt routine to determine the interrupted pin.

## (4) Registers related to the key-input interrupt

Figure 2.10.1 shows the memory map of key-input interrupt-related registers, and Figure 2.10.2 shows key-input interrupt-related registers.



Figure 2.10.1. Memory map of key-input interrupt-related registers



Figure 2.10.2. key-input interrupt-related registers

## 2.10.2 Operation of Key-Input Interrupt

The following is an operation of key-input interrupt. Figure 2.10.3 shows an example of a circuit that uses the key-input interrupt, Figure 2.10.4 shows an example of operation of key-input interrupt, and Figure 2.10.5 shows the setting procedure of key-input interrupt.

- Operation (1) Set the direction register of the ports to be changed to key-input interrupt pins to input, and set the pull-up function.
  - (2) Setting the key-input interrupt control register and setting the interrupt enable flag makes the interrupt-enabled state ready.
  - (3) If a falling edge is input to either  $\overline{\text{KI0}}$  through  $\overline{\text{KI7}}$ , the key-input interrupt request bit goes to "1".



Figure 2.10.3. Example of circuit using the key-input interrupt



Figure 2.10.4. Example of operation of key-input interrupt



Figure 2.10.5. Set-up procedure of key-input interrupt

#### 2.11 Power Control

## 2.11.1 Overview

'Power Control' refers to the reduction of CPU power consumption by stopping the CPU and oscillators, or decreasing the operation clock. The following is a description of the three available power control modes:

## (1) Modes

Power control is available in three modes.

#### (a) Normal operation mode

## • High-speed mode

Divide-by-1 frequency of the main clock becomes the BCLK. The CPU operates with the BCLK selected. Each peripheral function operates according to its assigned clock.

#### Medium-speed mode

Divide-by-2, divide-by-4, divide-by-8, or divide-by-16 frequency of the main clock becomes the BCLK. The CPU operates according to the BCLK selected. Each peripheral function operates according to its assigned clock.

#### Low-speed mode

fc becomes the BCLK. The CPU operates according to the fc clock. The fc clock is supplied by the secondary clock. Each peripheral function operates according to its assigned clock.

## • Low power consumption mode

The main clock operating in low-speed mode is stopped. The CPU operates according to the fc clock. The fc clock is supplied by the secondary clock. The only peripheral functions that operate are those with the sub-clock selected as the count source.

#### (b) Wait mode

The CPU operation is stopped. The oscillators do not stop.

## (c) Stop mode

All oscillators stop. The CPU and all built-in peripheral functions stop. This mode, among the three modes listed here, is the most effective in decreasing power consumption.

Figure 2.11.1 is the state transition diagram of the above modes.



Figure 2.11.1. State transition diagram of power control mode



#### (2) Switching the driving capacity of the oscillation circuit

Both the main clock and the secondary clock have the ability to switch the driving capacity. Reducing the driving capacity after the oscillation stabilizes allows for further reduction in power consumption.

#### (3) Clearing stop mode and wait mode

The stop mode and wait mode can be cleared by generating an interrupt request, or by resetting hardware. Set the priority level of the interrupt to be used for clearing, higher than the processor interrupt priority level (IPL), and enable the interrupt enable flag (I flag). When an interrupt clears a mode, that interrupt is processed. Table 2.11.1 shows the interrupts that can be used for clearing a stop mode and wait mode.

#### (4) BCLK in returning from wait mode or stop mode

#### (a) Returning from wait mode

The processor immediately returns to the BCLK, which was in use before entering wait mode.

#### (b) Returning from stop mode

If operation was performed in the high speed mode or medium speed mode prior to engaging the stop mode, CM06 will change to "1" when operation shifts to the stop mode. CM17, CM16 and CM07 do not change. Accordingly, when operation is restored from the stop mode, operation starts in the 8 division mode.

Also, if operation was performed in the low speed mode prior to engaging the stop mode, CM06, CM17, CM16 and CM07 do not change. When operation is restored from the stop mode, operation starts in the low speed mode.

Table 2.11.1. Interrupts available for clearing stop mode and wait mode

| Interrupt for clearing   | Wait mode |            |            |
|--------------------------|-----------|------------|------------|
| interrupt for cleaning   | CM02 = 0  | CM02 = 1   | Stop mode  |
| Key input interrupt      | Possible  | Possible   | Possible   |
| A-D interrupt            | Note 3    | Impossible | Impossible |
| UART0 transmit interrupt | Possible  | Note 1     | Note 1     |
| UART0 receive interrupt  | Possible  | Note 1     | Note 1     |
| UART1 transmit interrupt | Possible  | Impossible | Impossible |
| UART1 receive interrupt  | Possible  | Impossible | Impossible |
| Timer A0 interrupt       | Possible  | Note 2     | Note 2     |
| Timer B0 interrupt       | Possible  | Note 2     | Note 2     |
| Timer B1 interrupt       | Possible  | Note 2     | Note 2     |
| Timer X0 interrupt       | Possible  | Note 2     | Note 2     |
| Timer X1 interrupt       | Possible  | Note 2     | Note 2     |
| Timer X2 interrupt       | Possible  | Note 2     | Note 2     |
| INT0 interrupt           | Possible  | Possible   | Possible   |
| INT1 interrupt           | Possible  | Possible   | Possible   |

Note 1: Can be used when an external clock in clock synchronous serial I/O mode is selected.

Note 2: Can be used when the external signal is being counted in event counter mode.

Note 3: Can be used in one-shot mode and one-shot sweep mode.



#### (5) Sequence of returning from stop mode

Sequence of returning from stop mode is oscillation start-up time and interrupt sequence.

When interrupt is generated in stop mode, CM10 becomes "0" and clearing stop mode.

Starting oscillation and supplying BCLK execute the interrupt sequence as follow:

In the interrupt sequence, the processor carries out the following in sequence given:

- (a) CPU gets the interrupt information (the interrupt number and interrupt request level) by reading address 0000016. The interrupt request bit of the interrupt written in address 0000016 will then be set to "0".
- (b) Saves the content of the flag register (FLG) as it was immediately before the start of interrupt sequence in the temporary register (Note) within the CPU.
- (c) Sets the interrupt enable flag (I flag), the debug flag (D flag), and the stack pointer assignment flag (U flag) to "0" (the U flag, however does not change if the INT instruction, in software interrupt numbers 32 through 63, is executed)
- (d) Saves the content of the temporary register (Note) within the CPU in the stack area.
- (e) Saves the content of the program counter (PC) in the stack area.
- (f) Sets the interrupt priority level of the accepted instruction in the IPL.

Note: This register cannot be utilized by the user.

After the interrupt sequence is completed, the processor resumes executing instructions from the first address of the interrupt routine.

Figure 2.11.2 shows the sequence of returning from stop mode.



Figure 2.11.2. Sequence of returning from stop mode

#### (6) Registers related to power control

Figure 2.11.3 shows the memory map of power control-related registers, and Figure 2.11.4 shows power control-related registers.

000616 System clock control register 0 (CM0) 000716 System clock control register 1 (CM1)

Figure 2.11.3. Memory map of power control-related registers



Note 1: Set bit 0 of the protect register (address 000A16) to "1" before writing to this register. Note 2: Changes to "1" when shifting to stop mode and at a reset.

Note 3: This bit is used to stop the main clock when placing the device in a low-power mode. If you want to operate with XIN after exiting from the stop mode, set this bit to "0". When operating with a self-excited oscillator, set the system clock select bit (CM07) to "1" before setting this bit to "1".

Note 4: When inputting external clock, only clock oscillation buffer is stopped and clock input is acceptable.

Note 5: If this bit is set to "1", XOUT turns "H". The built-in feedback resistor remains being connected, so XIN turns pulled up to XOUT ("H") via the feedback resistor.

Note 6: Set port Xc select bit (CM04) to "1" and stabilize the sub-clock oscillating before setting to this bit from "0" to "1".

Do not write to both bits at the same time. And also, set the main clock stop bit (CM05) to "0" and stabilize the main clock

oscillating before setting this bit from "1" to "0".

Note 7: This bit changes to "1" when shifting from high-speed/medium-speed mode to stop mode and at a reset. When shifting from low-speed/low power dissipation mode to stop mode, the value before stop mode is retained.

Note 8: fc32 is not included.

b7 b6 b5 b4 b3 b2 b1 b0

#### System clock control register 1 (Note 1)

| 0 0 0 0 | Symbol<br>CM1 | Address<br>000716                           | When reset 2016                                       |     |
|---------|---------------|---------------------------------------------|-------------------------------------------------------|-----|
|         | Bit symbol    | Bit name                                    | Function                                              | RW  |
| -       | CM10          | All clock stop control bit (Note 4)         | 0 : Clock on<br>1 : All clocks off (stop mode)        | 00  |
|         | Reserved      | bit                                         | Always set to "0"                                     | 00  |
|         | Reserved      | bit                                         | Always set to "0"                                     | 00  |
|         | Reserved      | bit                                         | Always set to "0"                                     | 00  |
|         | Reserved      | bit                                         | Always set to "0"                                     | 00  |
|         | CM15          | XIN-XOUT drive capacity select bit (Note 2) | 0 : LOW<br>1 : HIGH                                   | 00  |
|         | CM16          | Main clock division select bit 1 (Note 3)   | 0 0 : No division mode<br>0 1 : Division by 2 mode    | 0 0 |
| L       | CM17          | . ,                                         | 1 0 : Division by 4 mode<br>1 1 : Division by 16 mode |     |

Note 1: Set bit 0 of the protect register (address 000A<sub>16</sub>) to "1" before writing to this register.

Note 2: This bit changes to "1" when shifting from high-speed/medium-speed mode to stop mode and at a reset. When shifting from low-speed/low power dissipation mode to stop mode, the value before stop mode is retained.

Note 3: Can be selected when bit 6 of the system clock control register 0 (address 000616) is "0". If "1", division mode is fixed at 8.

Note 4: If this bit is set to "1", XOUT turns "H", and the built-in feedback resistor is cut off. XCIN and XCOUT turn high-impedance state.

Figure 2.11.4. Power control-related registers



#### 2.11.2 Stop Mode Set-Up

Settings and operation for entering stop mode are described here.

Operation (1) Enables the interrupt used for returning from stop mode.

- (2) Sets the interrupt enable flag (I flag) to "1".
- (3) Clearing the protection and setting every-clock stop bit to "1" stops oscillation and causes the processor to go into stop mode.



Figure 2.11.5. Example of stop mode set-up



#### 2.11.3 Wait Mode Set-Up

Settings and operation for entering wait mode are described here.

Operation (1) Enables the interrupt used for returning from wait mode.

- (2) Sets the interrupt enable flag (I flag) to "1".
- (3) Clears the protection and changes the content of the system clock control register.
- (4) Executes the WAIT instruction.



Figure 2.11.6. Example of wait mode set-up

#### 2.11.4 Precautions in Power Control

- (1) When returning from stop mode by hardware reset, RESET pin must be set to "L" level until main clock oscillation is stabilized.
- (2) When switching to either wait mode or stop mode, instructions occupying four bytes either from the WAIT instruction or from the instruction that sets the every-clock stop bit to "1" within the instruction queue are prefetched and then the program stops. So put at least four NOPs in succession either to the WAIT instruction or to the instruction that sets the every-clock stop bit to "1".
- (3) Suggestions to reduce power consumption

#### Ports

The processor retains the state of each programmable I/O port even when it goes to wait mode or to stop mode. A current flows in active I/O ports. A pass current flows in input ports that float. When entering wait mode or stop mode, set non-used ports to input and stabilize the potential.

#### (a) A-D converter

A current always flows in the VREF pin. When entering wait mode or stop mode, set the Vref connection bit to "0" so that no current flows into the VREF pin.

#### (b) Stopping peripheral functions

In wait mode, stop non-used wait peripheral functions using the peripheral function clock stop bit.

#### (c) Switching the oscillation-driving capacity

Set the driving capacity to "LOW" when oscillation is stable.

#### (d) External clock

When using an external clock input for the CPU clock, set the main clock stop bit to "1". Setting the main clock stop bit to "1" causes the XOUT pin not to operate and the power consumption goes down (when using an external clock input, the clock signal is input regardless of the content of the main clock stop bit).

#### 2.12 Programmable I/O Ports

#### 2.12.1 Overview

Fourty-three programmable I/O ports. I/O pins also serve as I/O pins for built-in peripheral functions. Each port has a direction register that defines the I/O direction and also has a port register for I/O data. In addition, each port has a pull-up control register that defines pull-up in terms of 4 bits. Port P1 can be set to N-channel output transistor drive capacity.

The following is an overview of the programmable I/O ports:

#### (1) Writing to a port register

With the direction register set to output, the level of the written values from each relevant pin is output by writing to a port register. The output level conforms to CMOS output. Writing to the port register, with the direction register set to input, inputs a value to the port register, but nothing is output to the relevant pins. The output level remains floating.

#### (2) Reading a port register

With the direction register set to output, reading a port register takes out the content of the port register, not the content of the pin. With the direction register set to input, reading the port register takes out the content of the pin.

#### (3) Effect of the protection register

Data written to the direction register of P4 is affected by the protection register. The direction register of P4 cannot be easily rewritten.

#### (4) Setting pull-up

The pull-up control bit allows setting of the pull-up, in terms of 4 bits, either in use or not in use. For the four bits chosen, pull-up is effective only in the ports whose direction register is set to input. Pull-up is not effective in ports whose direction register is set to output.

Do not set pull-up of corresponding pin when XCIN/XCOUT is set or a port is used as A-D input.

#### (5) Drive capacity control

The drive capacity of the N channel output transistor on P1 can be set between "LOW" and "HIGH" in units of 1 bit. One bit corresponds to one pin.

#### (6) I/O functions of built-in peripheral devices

Table 2.12.1 shows relation between ports and I/O functions of built-in peripheral devices.

Table 2.12.1. Relation between ports and I/O functions of built-in peripheral devices

| Port       | Internal peripheral device I/O pins                            |
|------------|----------------------------------------------------------------|
| P0         | key-input interrupt function input pins                        |
| P40        | I/O pin for serial I/O communication/Timer A input pin         |
| P41        | Timer A output pin                                             |
| P42        | Serial I/O input pin                                           |
| P43, P44   | Input pins for external interrupt/Timer X I/O pins             |
| P45        | Timer X I/O pin                                                |
| P50 to P54 | I/O pins for serial I/O communication/A-D converter input pins |
| P6         | A-D converter input pins                                       |
| P70, P71   | Timer B input pins                                             |

#### (7) Examples of working on non-used pins

Table 2.12.2 contains examples of working on non-used pins. There are shown here for mere examples. In practical use, make suitable changes and perform sufficient evaluation in compliance with you application.

Table 2.12.2. Examples of working on unused pins in single-chip mode

| Pin name               | Connection                                                                                                                                      |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Ports P0, P1, P3 to P7 | After setting for input mode, connect every pin to Vss or Vcc via a resistor; or after setting for output mode, leave these pins open. (Note 1) |
| XOUT (Note 2)          | Open                                                                                                                                            |
| AVcc                   | Connect to Vcc                                                                                                                                  |
| AVSS, VREF, BYTE       | Connect to Vss                                                                                                                                  |

Note 1: If setting these pins in output mode and opening them, ports are in input mode until switched into output mode by use of software after reset. Thus the voltage levels of the pins become unstable, and there can be instances in which the power source current increases while the ports are in input mode.

In view of an instance in which the contents of the direction registers change due to a runaway generated by noise or other causes, setting the contents of the direction registers periodically by use of software increases program reliability.

Note 2: When an external clock is input to the XIN pin.

#### (8) Registers related to the programmable I/O ports

Figure 2.12.1 shows the memory map of programmable I/O ports-related registers, and Figures 2.12.2 to 2.12.4 show programmable I/O ports-related registers.

| 03E0 <sub>16</sub> | Port P0 (P0)                         |   |
|--------------------|--------------------------------------|---|
| 03E1 <sub>16</sub> | Port P1 (P1)                         |   |
| 03E2 <sub>16</sub> | Port P0 direction register (PD0)     |   |
| 03E3 <sub>16</sub> | Port P1 direction register (PD1)     |   |
| 03E4 <sub>16</sub> |                                      |   |
| 03E5 <sub>16</sub> | Port P3 (P3)                         |   |
| 03E6 <sub>16</sub> |                                      |   |
| 03E7 <sub>16</sub> | Port P3 direction register (PD3)     |   |
| 03E816             | Port P4 (P4)                         |   |
| 03E9 <sub>16</sub> | Port P5 (P5)                         |   |
| 03EA <sub>16</sub> | Port P4 direction register (PD4)     |   |
| 03EB <sub>16</sub> | Port P5 direction register (PD5)     |   |
| 03EC <sub>16</sub> | Port P6 (P6)                         |   |
| 03ED <sub>16</sub> | Port P7 (P7)                         |   |
| 03EE <sub>16</sub> | Port P6 direction register (PD6)     |   |
| 03EF <sub>16</sub> | Port P7 direction register (PD7)     |   |
| $\approx$          |                                      | ∻ |
| 03FC <sub>16</sub> | Pull-up control register 0 (PUR0)    |   |
| 03FD <sub>16</sub> | Pull-up control register 1 (PUR1)    |   |
| 03FE <sub>16</sub> | Port P1 drive control register (DRR) |   |

Figure 2.12.1. Memory map of programmable I/O ports-related registers



Figure 2.12.2. Programmable I/O ports-related registers (1)



Figure 2.12.3. Programmable I/O ports-related registers (2)

### Chapter 3

**Examples of Peripheral functions Applications** 



This chapter presents applications in which peripheral functions built in the M16C/20 are used. They are shown here as examples. In practical use, make suitable changes and perform sufficient evaluation. For basic use, see Chapter 2 How to Use Peripheral Functions.

Here follows the list of applications that appear in this chapter.

| 3.1 Long-period timers                            | P326 |
|---------------------------------------------------|------|
| 3.2 Variable-period variable-duty PWM output      | P330 |
| 3.3 Delayed one-shot output                       | P334 |
| 3.4 Buzzer output                                 | P338 |
| 3.5 Solution for external interrupt pins shortage | P340 |
| 3.6 Controlling power using stop mode             | P342 |
| • 3.7 Controlling power using wait mode           | P346 |





#### 3.1 Long-Period Timers

Overview In this process, Timer X0 and Timer X1 are connected to make a 16-bit timer with a 16-bit prescaler. Figure 3.1.1 shows the operation timing, Figure 3.1.2 shows the connection diagram, and Figures 3.1.3 and 3.1.4 show the set-up procedure.

Use the following peripheral functions:

- Timer mode of timer X
- Event counter mode of timer X

#### **Specifications**

- (1) Set timer X0 to timer mode, and set timer X1 to event counter mode.
- (2) Perform a count on count source f1 using timer X0 to count for 1 ms, and perform a count on timer X0 using timer X1 to count for 1 second.
- (3) Connect a 10-MHz oscillator to XIN.

Operation (1) Setting the count start flag to "1" causes the counter to begin counting. The counter of timer X0 performs a down count on count source f1.

- (2) If the counter of timer X0 underflows, the counter reloads the content of the reload register and continues counting. At this time, the timer X0 interrupt request bit goes to "1". The counter of timer X1 performs a down count on underflows in timer X0.
- (3) If the counter of timer X1 underflows, the counter reloads the content of the reload register and continues counting. At this time, the timer X1 interrupt request bit goes to "1".



Figure 3.1.1. Operation timing of long-period timers



Figure 3.1.2. Connection diagram of long-period timers



Figure 3.1.3. Set-up procedure of long-period timers (1)



Figure 3.1.4. Set-up procedure of long-period timers (2)

#### 3.2 Variable-Period Variable-Duty PWM Output

Overview In this process, Timer X0 and A1 are used to generate variable-period, variable-duty PWM output. Figure 3.2.1 shows the operation timing, Figure 3.2.2 shows the connection diagram, and Figures 3.2.3 and 3.2.4 show the set-up procedure.

Use the following peripheral functions:

- Timer mode of timer X
- One-shot timer mode of timer X

#### **Specifications**

- (1) Set timer X0 in timer mode, and set timer X1 in one-shot timer mode with pulse-output function.
- (2) Set 1 ms, the PWM period, to timer X0. Set 500 μs, the width of PWM "H" pulse, to timer X1. Both timer X0 and timer X1 use f1 for the count source.
- (3) Connect a 10-MHz oscillator to XIN.
- Operation (1) Setting the count start flag to "1" causes the counter of timer X0 to begin counting. The counter of timer X0 performs a down count on count source f1.
  - (2) If the counter of timer X0 underflows, the counter reloads the content of the reload register and continues counting. At this time, the timer X0 interrupt request bit gose to "1".
  - (3) An underflow in timer X0 triggers the counter of timer X1 and causes it to begin counting. When the counter of timer X1 begins counting, the output level of the TX1INOUT pin gose to "H".
  - (4) As soon as the count of the counter of timer X1 becomes "000016", the output level of TX1INOUT pin gose to "L", and the counter reloads the content of the reload register and stops counting. At the same time, the timer X1 interrupt request bit gose to "1".



Figure 3.2.1. Operation timing of variable-period variable-duty PWM output



Figure 3.2.2. Connection diagram of variable-period variable-duty PWM output



Figure 3.2.3. Set-up procedure of variable-period variable-duty PWM output (1)



Figure 3.2.4. Set-up procedure of variable-period variable-duty PWM output (2)

#### 3.3 Delayed One-Shot Output

Overview The following are steps of outputting a pulse only once after a specified elapse since an external trigger is input. Figure 3.3.1 shows the operation timing, Figure 3.3.2 shows the connection diagram, and Figures 3.3.3 and 3.3.4 show the set-up procedure.

Use the following peripheral function:

One-shot timer mode of timer X

#### Specifications

- (1) Set timer X0 in one-shot timer mode, and set timer X1 in one-shot timer mode with pulseoutput function.
- (2) Set 1 ms, an interval before a pulse is output, in timer X0; and set 50  $\mu$ s, a pulse width, in timer X1. Both timer X0 and timer X1 use f1 for the count source.
- (3) Connect a 10-MHz oscillator to XIN.

Operation (1) Setting the trigger select bit to "1" and setting the count start flag to "1" enables the counter of timer X0 to count.

- (2) If an effective edge, selected by use of the external trigger select bit, is input to the TX0INOUT pin, the counter begins a down count. The counter of timer X0 performs a down count on count source f1.
- (3) As soon as the counter of timer X0 becomes "000016", the counter reloads the content of the reload register and stops counting. At this time, the timer X0 interrupt request bit gose to "1".
- (4) An underflow in timer X0 triggers the counter of timer X1 and causes it to begin counting. When timer X1 begins counting, the output level of the TX1INOUT pin gose to "H".
- (5) As soon as the counter of timer X1 becomes "000016", the output level of the TX1INOUT pin gose to "L", the counter reloads the content of the reload register, and stops counting. At this time, timer X1 interrupt request bit gose to "1".



Figure 3.3.1. Operation timing of delayed one-shot output



Figure 3.3.2. Connection diagram of delayed one-shot output



Figure 3.3.3. Set-up procedure of delayed one-shot output (1)



Figure 3.3.4. Set-up procedure of delayed one-shot output (2)

#### 3.4 Buzzer Output

Overview The timer mode is used to make the buzzer ring. Figure 3.4.1 shows the operation timing, and Figure 3.4.2 shows the set-up procedure.

Use the following peripheral function:

• The pulse-outputting function in timer mode of timer X.

#### **Specifications**

- (1) Sound a 2-kHz buzz beep by use of timer X0.
- (2) Effect pull-up in the relevant port by use of a pull-up resistor. When the buzzer is off, set the port high-impedance, and stabilize the potential resulting from pulling up.
- (3) Connect a 10-MHz oscillator to XIN.

Operation (1) The microcomputer begins performing a count on timer X0. Timer X0 has disabled interrupts.

- (2) P43 is TX0INOUT pin. Setting the port P43 direction register to "1" (output mode) and outputs 2-kHz pulses.
- (3) The microcomputer stops outputting pulses by setting the port P43 direction register to "0" (input mode). P43 goes to an input pin, and the output from the pin becomes high-impedance.



Figure 3.4.1. Operation timing of buzzer output



Figure 3.4.2. Set-up procedure of buzzer output



#### 3.5 Solution for External Interrupt Pins Shortage

Overview The following are solution for external interrupt pins shortage. Figure 3.5.1 shows the set-up procedure.

Use the following peripheral function:

• Event counter mode of timer X

#### **Specifications**

- (1) Inputting a falling edge to the TX0INOUT pin generates a timer X0 interrupt.
- Operation (1) Set timer X0 to event counter mode, set timer to "0", and set interrupt priority levels in timer X0.
  - (2) Inputting a falling edge to the TX0INOUT pin generates a timer X0 interrupt.



Figure 3.5.1. Set-up procedure of solution for a shortage of external interrupt pins

#### 3.6 Controlling Power Using Stop Mode

Overview

Under

The following are steps for controlling power using stop mode. Figure 3.6.1 shows the operation timing, Figure 3.6.2 shows an example of circuit, and Figures 3.6.3 and 3.6.4 show the set-up procedure.

Use the following peripheral functions:

- Key-input interrupts
- Stop mode
- Pull-up function

#### **Specifications**

- (1) Use P30 through P33 for the scan output pins of a key matrix. Use the input pins (KI0 through KI7) of the key-input interrupt function for the key-input reading pins. The pull-up function is also used.
- (2) If a key-input interrupt request occurs, clear the stop mode and read a key.

Operation

- (1) Enable a key-input interrupt and set the pull-up function to pins  $\overline{\text{Klo}}$  through  $\overline{\text{Kl7}}$ . Change the output of P30 through P33 to "L" and enter stop mode.
- (2) If a key is pressed, "L" is input to one of pins Klo through Kl7 to clear stop mode. A key-input interrupt occurs to execute the key-input interrupt handling routine.
- (3) Sequentially set P30 through P33 to "L" to determine which key was pressed.
- (4) When the process to determine the key pressed is completed, change the output from P30 through P33 to "L" again and enter stop mode.



Figure 3.6.1. Operation timing of controlling power using stop mode





Figure 3.6.2. Example of circuit of controling power using stop mode

# Jude loonent



Figure 3.6.3. Set-up procedure of controlling power using stop mode (1)





Figure 3.6.4. Set-up procedure of controlling power using stop mode (2)

## Under Johnent

#### 3.7 Controling Power Using Wait Mode

Overview The following are steps for controlling power using wait mode. Figure 3.7.1 shows the operation timing, and Figures 3.7.2 to 3.7.4 show the set-up procedure.

Use the following peripheral functions:

- Timer mode of timer B
- Wait mode

A flag named "F-WIT" is used in the set-up procedure. The purpose of this flag is to decide whether or not to clear wait mode. If F\_WIT = "1" in the main program, the wait mode is entered; if F\_WIT = "0", the wait mode is cleared.

#### **Specifications**

- (1) Connect a 32.768-kHz oscillator to XCIN to serve as the timer count source. As interrupts occur every one second, which is a count the timer reaches, the controller returns from wait mode and count the clock using a program.
- (2) Clear wait mode if a INTO interrupt request occurs.

Operation (1) Switch the system clock from XIN to XCIN to get low-speed mode.

- (2) Stop XIN and enter wait mode. In this instance, enable the timer B0 interrupt and the INTO interrupt.
- (3) When a timer B0 interrupt request occurs (at 1-second intervals), start supplying the BCLK from XCIN.
  - At this time, count the clock within the routine that handles the timer B0 interrupts and enter wait mode again.
- (4) If a INTO interrupt occurs, start supplying the BCLK from XCIN. Start the XIN oscillation within the INTO interrupt, and switch the system clock to XIN.



Figure 3.7.1. Operation timing of controling power using wait mode





Figure 3.7.2. Set-up procedure of controlling power using wait mode (1)





Figure 3.7.3. Set-up procedure of controlling power using wait mode (2)





Figure 3.7.4. Set-up procedure of controlling power using wait mode (3)

## Chapter 4

Interrupt

## 4.1 Overview of Interrupt

## 4.1.1 Type of Interrupts

Figure 4.1.1 lists the types of interrupts.



Figure 4.1.1. Classification of interrupts

Maskable interrupt:
 An interrupt which can be enabled (disabled) by the interrupt enable flag

(I flag) or whose interrupt priority can be changed by priority level.

• Non-maskable interrupt : An interrupt which cannot be enabled (disabled) by the interrupt enable

flag (I flag) or whose interrupt priority cannot be changed by priority level.



## 4.1.2 Software Interrupts

A software interrupt occurs when executing certain instructions. Software interrupts are non-maskable interrupts.

#### Undefined instruction interrupt

An undefined instruction interrupt occurs when executing the UND instruction.

#### Overflow interrupt

An overflow interrupt occurs when executing the INTO instruction with the overflow flag (O flag) set to "1". The following are instructions whose O flag changes by arithmetic:

ABS, ADC, ADCF, ADD, CMP, DIV, DIVU, DIVX, NEG, RMPA, SBB, SHA, SUB

#### BRK interrupt

A BRK interrupt occurs when executing the BRK instruction.

#### INT interrupt

An INT interrupt occurs when assiging one of software interrupt numbers 0 through 63 and executing the INT instruction. Software interrupt numbers 0 through 31 are assigned to peripheral I/O interrupts, so executing the INT instruction allows executing the same interrupt routine that a peripheral I/O interrupt does.

The stack pointer (SP) used for the INT interrupt is dependent on which software interrupt number is involved.

So far as software interrupt numbers 0 through 31 are concerned, the microcomputer saves the stack pointer assignment flag (U flag) when it accepts an interrupt request. If change the U flag to "0" and select the interrupt stack pointer (ISP), and then execute an interrupt sequence. When returning from the interrupt routine, the U flag is returned to the state it was before the acceptance of interrupt request. So far as software numbers 32 through 63 are concerned, the stack pointer does not make a shift.



#### 4.1.3 Hardware Interrupts

Hardware interrupts are classified into two types — special interrupts and peripheral I/O interrupts.

#### (1) Special interrupts

Special interrupts are non-maskable interrupts.

#### Reset

Reset occurs if an "L" is input to the RESET pin.

#### DBC interrupt

This interrupt is exclusively for the debugger, do not use it in other circumstances.

#### Watchdog timer interrupt

Generated by the watchdog timer.

#### Single-step interrupt

This interrupt is exclusively for the debugger, do not use it in other circumstances. With the debug flag (D flag) set to "1", a single-step interrupt occurs after one instruction is executed.

#### Address match interrupt

An address match interrupt occurs immediately before the instruction held in the address indicated by the address match interrupt register is executed with the address match interrupt enable bit set to "1". If an address other than the first address of the instruction in the address match interrupt register is set, no address match interrupt occurs. For address match interrupt, see 2.9 Address match Interrupt.

#### (2) Peripheral I/O interrupts

A peripheral I/O interrupt is generated by one of built-in peripheral functions. Built-in peripheral functions are dependent on classes of products, so the interrupt factors too are dependent on classes of products. The interrupt vector table is the same as the one for software interrupt numbers 0 through 31 the INI instruction uses. Peripheral I/O interrupts are maskable interrupts.

#### Key-input interrupt

A key-input interrupt occurs if an "L" is input to the  $\overline{\text{KI}}$  pin.

#### A-D conversion interrupt

This is an interrupt that the A-D converter generates.

#### UART0 and UART1 transmission interrupt

These are interrupts that the serial I/O transmission generates.

#### UART0 and UART1 reception interrupt

These are interrupts that the serial I/O reception generates.

#### • Timer A0 interrupt

This is an interrupt that timer A generates.

## Timer B0 interrupt and timer B1 interrupt

These are interrupts that timer B generates.

#### • Timer X0 interrupt through timer X2 interrupt

#### • INTO interrupt and INT1 interrupt

An INT interrupt occurs if either a rising edge or a falling edge is input to the INT pin.



## 4.1.4 Interrupts and Interrupt Vector Tables

If an interrupt request is accepted, a program branches to the interrupt routine set in the interrupt vector table. Set the first address of the interrupt routine in each vector table. Two types of interrupt vector tables are available — fixed vector table in which addresses are fixed and variable vector table in which addresses can be varied by the setting.

#### Fixed vector tables

The fixed vector table is a table in which addresses are fixed. The vector tables are located in an area extending from FFFDC16 to FFFFF16. One vector table comprises four bytes. Set the first address of interrupt routine in each vector table. Table 4.1.1 shows the interrupts assigned to the fixed vector tables and addresses of vector tables.

Table 4.1.1. Interrupts assigned to the fixed vector tables and addresses of vector tables

| Interrupt source      | Vector table addresses     | Remarks                                                      |
|-----------------------|----------------------------|--------------------------------------------------------------|
|                       | Address (L) to address (H) |                                                              |
| Undefined instruction | FFFDC16 to FFFDF16         | Interrupt on UND instruction                                 |
| Overflow              | FFFE016 to FFFE316         | Interrupt on INTO instruction                                |
| BRK instruction       | FFFE416 to FFFE716         | If the vector contains FF16, program execution starts from   |
|                       |                            | the address shown by the vector in the variable vector table |
| Address match         | FFFE816 to FFFEB16         | There is an address-matching interrupt enable bit            |
| Single step (Note)    | FFFEC16 to FFFEF16         | Do not use                                                   |
| Watchdog timer        | FFFF016 to FFFF316         |                                                              |
| DBC (Note)            | FFFF416 to FFFF716         | Do not use                                                   |
|                       | FFFF816 to FFFFB16         |                                                              |
| Reset                 | FFFFC16 to FFFFF16         |                                                              |

Note: Interrupts used for debugging purposes only.



#### Variable vector tables

The addresses in the variable vector table can be modified, according to the user's settings. Indicate the first address using the interrupt table register (INTB). The 256-byte area subsequent to the address the INTB indicates becomes the area for the variable vector tables. One vector table comprises four bytes. Set the first address of the interrupt routine in each vector table. Table 4.1.2 shows the interrupts assigned to the variable vector tables and addresses of vector tables.

Table 4.1.2. Interrupts assigned to the variable vector tables and addresses of vector tables

| Software interrupt number          | Vector table address<br>Address (L) to address (H) | Interrupt source    | Remarks                    |
|------------------------------------|----------------------------------------------------|---------------------|----------------------------|
| Software interrupt number 0        | +0 to +3 (Note)                                    | BRK instruction     | Cannot be masked by I flag |
|                                    |                                                    |                     |                            |
| Software interrupt number 11       | +44 to +47 (Note)                                  |                     |                            |
| Software interrupt number 12       | +48 to +51 (Note)                                  |                     |                            |
| Software interrupt number 13       | +52 to +55 (Note)                                  | Key input interrupt |                            |
| Software interrupt number 14       | +56 to +59 (Note)                                  | A-D                 |                            |
|                                    |                                                    |                     |                            |
| Software interrupt number 17       | +68 to +71 (Note)                                  | UART0 transmit      |                            |
| Software interrupt number 18       | +72 to +75 (Note)                                  | UART0 receive       |                            |
| Software interrupt number 19       | +76 to +79 (Note)                                  | UART1 transmit      |                            |
| Software interrupt number 20       | +80 to +83 (Note)                                  | UART1 receive       |                            |
| Software interrupt number 21       | +84 to +87 (Note)                                  | Timer A0            |                            |
| Software interrupt number 22       | +88 to +91 (Note)                                  | Timer X0            |                            |
| Software interrupt number 23       | +92 to +95 (Note)                                  | Timer X1            |                            |
| Software interrupt number 24       | +96 to +99 (Note)                                  | Timer X2            |                            |
| Software interrupt number 25       | +100 to +103 (Note)                                |                     |                            |
| Software interrupt number 26       | +104 to +107 (Note)                                | Timer B0            |                            |
| Software interrupt number 27       | +108 to +111 (Note)                                | Timer B1            |                            |
| Software interrupt number 28       | +112 to +115 (Note)                                |                     |                            |
| Software interrupt number 29       | +116 to +119 (Note)                                | ĪNT0                |                            |
| Software interrupt number 30       | +120 to +123 (Note)                                | ĪNT1                |                            |
| Software interrupt number 31       | +124 to +127 (Note)                                |                     |                            |
| Software interrupt number 32       | +128 to +131 (Note)                                |                     |                            |
| to<br>Software interrupt number 63 | to<br>+252 to +255 (Note)                          | Software interrupt  | Cannot be masked by I flag |
|                                    |                                                    |                     |                            |

Note: Address relative to address in interrupt table register (INTB).



## 4.2 Interrupt Control

Descriptions are given here regarding how to enable or disable maskable interrupts and how to set the priority to be accepted. What is described here does not apply to non-maskable interrupts.

Enable or disable a non-maskable interrupt using the interrupt enable flag (I flag), interrupt priority level selection bit, or processor interrupt priority level (IPL). Whether an interrupt request is present or absent is indicated by the interrupt request bit. The interrupt request bit and the interrupt priority level selection bit are located in the interrupt control register of each interrupt. Also, the interrupt enable flag (I flag) and the IPL are located in the flag register (FLG).

Table 4.2.1 shows the memory map of the interrupt control registers, and Table 4.2.2 shows the interrupt control registers.

| 004D16            | Key input interrupt control register(KUPIC)       |
|-------------------|---------------------------------------------------|
| 004E16            | A-D conversion interrupt control register (ADIC)  |
| 004F16            |                                                   |
| 005016            |                                                   |
| 05116             | UART0 transmit interrupt control register (S0TIC) |
| 05216             | UART0 receive interrupt control register (S0RIC)  |
| 05316             | UART1 transmit interrupt control regster(S1TIC)   |
| 05416             | UART1 receive interrupt control register(S1RIC)   |
| 05516             | Timer A0 interrupt control register (TA0IC)       |
| 05616             | Timer X0 interrupt control register (TX0IC)       |
| 05716             | Timer X1 interrupt control register (TX1IC)       |
| 05816             | Timer X2 interrupt control register (TX2IC)       |
| 05916             |                                                   |
| 05A16             | Timer B0 interrupt control register (TB0IC)       |
| 05B16             | Timer B1 interrupt control register (TB1IC)       |
| 05C16             |                                                   |
| 05D16             | INT0 interrupt control register (INT0IC)          |
| 05E <sub>16</sub> | INT1 interrupt control register (INT1IC)          |

Table 4.2.1. Memory map of the interrupt control registers



Figure 4.2.2. Interrupt control registers



## 4.2.1 Interrupt Enable Flag

The interrupt enable flag (I flag) controls the enabling and disabling of maskable interrupts. Setting this flag to "1" enables all maskable interrupts; setting it to "0" disables all maskable interrupts. This flag is set to "0" after reset.

The content is changed when the I flag is changed causes the acceptance of the interrupt request in the following timing:

- When changing the I flag using the REIT instruction, the acceptance of the interrupt takes effect as the REIT instruction is executed.
- When changing the I flag using one of the FCLR, FSET, POPC, and LDC instructions, the acceptance of the interrupt is effective as the next instruction is executed.



Figure 4.2.3. The timing of reflecting the change in the I flag to the interrupt

## 4.2.2 Interrupt Request Bit

The interrupt request bit is set to "1" by hardware when an interrupt is requested. After the interrupt is accepted and jumps to the corresponding interrupt vector, the request bit is set to "0" by hardware. The interrupt request bit can also be set to "0" by software. (Do not set this bit to "1").



## 4.2.3 Interrupt Priority Level Select Bit and Processor Interrupt Priority Level (IPL)

Set the interrupt priority level using the interrupt priority level select bit, which is one of the component bits of the interrupt control register. When an interrupt request occurs, the interrupt priority level is compared with the IPL. The interrupt is enabled only when the priority level of the interrupt is higher than the IPL. Therefore, setting the interrupt priority level to "0" disables the interrupt.

Table 4.2.1 shows the settings of interrupt priority levels and Table 4.2.2 shows the interrupt levels enabled, according to the consist of the IPL.

The following are conditions under which an interrupt is accepted:

- · interrupt enable flag (I flag) = 1
- · interrupt request bit = 1
- · interrupt priority level > IPL

The interrupt enable flag (I flag), the interrupt request bit, the interrupt priority select bit, and the IPL are independent, and they are not affected by one another.

Table 4.2.1. Settings of interrupt priority levels

| Interrupt priority level select bit | Interrupt priority<br>level  | Priority<br>order |
|-------------------------------------|------------------------------|-------------------|
| b2 b1 b0                            |                              |                   |
| 0 0 0                               | Level 0 (interrupt disabled) |                   |
| 0 0 1                               | Level 1                      | Low               |
| 0 1 0                               | Level 2                      |                   |
| 0 1 1                               | Level 3                      |                   |
| 1 0 0                               | Level 4                      |                   |
| 1 0 1                               | Level 5                      |                   |
| 1 1 0                               | Level 6                      |                   |
| 1 1 1                               | Level 7                      | High              |

Table 4.2.2. Interrupt levels enabled according to the contents of the IPL

| II.            | PL |                  | Enabled interrupt priority levels        |
|----------------|----|------------------|------------------------------------------|
| IPL2 IPL1 IPL0 |    | IPL <sub>0</sub> |                                          |
| 0              | 0  | 0                | Interrupt levels 1 and above are enabled |
| 0              | 0  | 1                | Interrupt levels 2 and above are enabled |
| 0              | 1  | 0                | Interrupt levels 3 and above are enabled |
| 0              | 1  | 1                | Interrupt levels 4 and above are enabled |
| 1              | 0  | 0                | Interrupt levels 5 and above are enabled |
| 1              | 0  | 1                | Interrupt levels 6 and above are enabled |
| 1              | 1  | 0                | Interrupt levels 7 and above are enabled |
| 1              | 1  | 1                | All maskable interrupts are disabled     |

When either the IPL or the interrupt priority level is changed, the new level is reflected to the interrupt in the following timing:

- When changing the IPL using the REIT instruction, the reflection takes effect as of the instruction that is executed in 2 clock cycles after the last clock cycle in volved in the REIT instruction.
- When changing the IPL using either the POPC, LDC or LDIPL instruction, the reflection takes effect as of the instruction that is executed in 3 cycles after the last clock cycle involved in the instruction used.
- When changing the interrupt priority level using the MOV or similar instruction, the reflection takes
  effect as of the instruction that is executed in 2 clock cycles after the last clock cycle involved in
  the instruction used.



## 4.2.4 Rewrite the interrupt control register

To rewrite the interrupt control register, do so at a point that does not generate the interrupt request for that register. If there is possibility of the interrupt request occur, rewrite the interrupt control register after the interrupt is disabled. The program examples are described as follow:

#### Example 1:

INT\_SWITCH1:

FCLR I ; Disable interrupts.

AND.B #00h, 0055h ; Clear TA0IC int. priority level and int. request bit.

NOP ; Four NOP instructions are required when using HOLD function.

NOP

FSET I ; Enable interrupts.

#### Example 2:

INT\_SWITCH2:

FCLR I ; Disable interrupts.

AND.B #00h, 0055h ; Clear TA0IC int. priority level and int. request bit.

MOV.W MEM, R0 ; Dummy read. FSET I ; Enable interrupts.

#### Example 3:

INT\_SWITCH3:

PUSHC FLG ; Push Flag register onto stack

FCLR I ; Disable interrupts.

AND.B #00h, 0055h ; Clear TA0IC int. priority level and int. request bit.

POPC FLG ; Enable interrupts.

The reason why two NOP instructions (four when using the HOLD function) or dummy read are inserted before FSET I in Examples 1 and 2 is to prevent the interrupt enable flag I from being set before the interrupt control register is rewritten due to effects of the instruction queue.

When a instruction to rewrite the interrupt control register is executed but the interrupt is disabled, the interrupt request bit is not set sometimes even if the interrupt request for that register has been generated. This will depend on the instruction. If this creates problems, use the below instructions to change the register.

Instructions: AND, OR, BCLR, BSET

## 4.3 Interrupt Sequence

An interrupt sequence — what are performed over a period from the instant an interrupt is accepted to the instant the interrupt routine is executed — is described here.

If an interrupt occurs during execution of an instruction, the processor determines its priority when the execution of the instruction is completed, and transfers control to the interrupt sequence from the next cycle. If an interrupt occurs during execution of either the SMOVB, SMOVF, SSTR or RMPA instruction, the processor temporarily suspends the instruction being executed, and transfers control to the interrupt sequence.

In the interrupt sequence, the processor carries out the following in sequence given:

- (1) CPU gets the interrupt information (the interrupt number and interrupt request level) by reading address 0000016.
- (2) Saves the content of the flag register (FLG) as it was immediately before the start of interrupt sequence in the temporary register (Note) within the CPU.
- (3) Sets the interrupt enable flag (I flag), the debug flag (D flag), and the stack pointer select flag (U flag) to "0" (the U flag, however does not change if the INT instruction, in software interrupt numbers 32 through 63, is executed)
- (4) Saves the content of the temporary register (Note 1) within the CPU in the stack area.
- (5) Saves the content of the program counter (PC) in the stack area.
- (6) Sets the interrupt priority level of the accepted instruction in the IPL.

After the interrupt sequence is completed, the processor resumes executing instructions from the first address of the interrupt routine.

Note: This register cannot be utilized by the user.

#### 4.3.1 Interrupt Response Time

'Interrupt response time' is the period between the instant an interrupt occurs and the instant the first instruction within the interrupt routine has been executed. This time comprises the period from the occurrence of an interrupt to the completion of the instruction under execution at that moment (a) and the time required for executing the interrupt sequence (b). Figure 4.3.1 shows the interrupt response time.



Figure 4.3.1. Interrupt response time



Time (a) is dependent on the instruction under execution. Thirty cycles is the maximum required for the DIVX instruction (without wait).

Time (b) is as shown in Table 4.3.1.

Table 4.3.1. Time required for executing the interrupt sequence

| Interrupt vector address Stack pointer (SP) value |      | 16-Bit bus, without wait | 8-Bit bus, without wait |  |
|---------------------------------------------------|------|--------------------------|-------------------------|--|
| Even                                              | Even | 18 cycles (Note 1)       | 20 cycles (Note 1)      |  |
| Even                                              | Odd  | 19 cycles (Note 1)       | 20 cycles (Note 1)      |  |
| Odd (Note 2)                                      | Even | 19 cycles (Note 1)       | 20 cycles (Note 1)      |  |
| Odd (Note 2)                                      | Odd  | 20 cycles (Note 1)       | 20 cycles (Note 1)      |  |

Note 1: Add 2 cycles in the case of a DBC interrupt; add 1 cycle in the case either of an address coincidence interrupt or of a single-step interrupt.

Note 2: Locate an interrupt vector address in an even address, if possible.



Figure 4.3.2. Time required for executing the interrupt sequence

## 4.3.2 Variation of IPL when Interrupt Request is Accepted

If an interrupt request is accepted, the interrupt priority level of the accepted interrupt is set in the IPL. If an interrupt request, that does not have an interrupt priority level, is accepted, one of the values shown in Table 4.3.2 is set in the IPL.

Table 4.3.2. Relationship between interrupts without interrupt priority levels and IPL

| Interrupt sources without priority levels | Value set in the IPL |  |
|-------------------------------------------|----------------------|--|
| Watchdog timer                            | 7                    |  |
| Reset                                     | 0                    |  |
| Other                                     | Not changed          |  |

## 4.3.3 Saving Registers

In the interrupt sequence, only the contents of the flag register (FLG) and that of the program counter (PC) are saved in the stack area.

First, the processor saves the four higher-order bits of the program counter, and 4 upper-order bits and 8 lower-order bits of the FLG register, 16 bits in total, in the stack area, then saves 16 lower-order bits of the program counter. Figure 4.3.3 shows the state of the stack as it was before the acceptance of the interrupt request, and the state the stack after the acceptance of the interrupt request.

Save other necessary registers at the beginning of the interrupt routine using software. Using the PUSHM instruction alone can save all the registers except the stack pointer (SP).



Figure 4.3.3. State of stack before and after acceptance of interrupt request

The operation of saving registers carried out in the interrupt sequence is dependent on whether the content of the stack pointer, at the time of acceptance of an interrupt request, is even or odd. If the content of the stack pointer (Note) is even, the content of the flag register (FLG) and the content of the program counter (PC) are saved, 16 bits at a time. If odd, their contents are saved in two steps, 8 bits at a time. Figure 4.3.4 shows the operation of the saving registers.

Note: Stack pointer indicated by U flag.



Figure 4.3.4. Operation of saving registers

## 4.4 Returning from an Interrupt Routine

Executing the REIT instruction at the end of an interrupt routine returns the contents of the flag register (FLG) as it was immediately before the start of interrupt sequence and the contents of the program counter (PC), both of which have been saved in the stack area. Then control returns to the program that was being executed before the acceptance of the interrupt request, so that the suspended process resumes.

Return the other registers saved by software within the interrupt routine using the POPM or similar instruction before executing the REIT instruction.

## 4.5 Interrupt Priority

If there are two or more interrupt requests occurring at a point in time within a single sampling (checking whether interrupt requests are made), the interrupt assigned a higher priority is accepted.

Assign an arbitrary priority to maskable interrupts (peripheral I/O interrupts) using the interrupt priority level select bit. If the same interrupt priority level is assigned, however, the interrupt assigned a higher hardware priority is accepted (see Figure 4.5.1).

Priorities of the special interrupts, such as Reset (dealt with as an interrupt assigned the highest priority), watchdog timer interrupt, etc. are regulated by hardware.

Figure 4.5.2 shows the priorities of hardware interrupts.

Software interrupts are not affected by the interrupt priority. If an instruction is executed, control branches invariably to the interrupt routine.



Figure 4.5.1. Maskable interrupts priorities (peripheral I/O interrupts)

Reset > DBC > Watchdog timer > Peripheral I/O > Single step > Address match

Figure 4.5.2. Hardware interrupts priorities

## 4.6 Multiple Interrupts

The state when control branched to an interrupt routine is described below:

- The interrupt enable flag (I flag) is set to "0" (the interrupt is disabled).
- · The interrupt request bit of the accepted interrupt is set to "0".
- The processor interrupt priority level (IPL) is assigned to the same interrupt priority level as assigned to the accepted interrupt.

Setting the interrupt enable flag (I flag) to "1" within an interrupt routine allows an interrupt request assigned a priority higher than the IPL to be accepted. Figure 4.6.1 shows the scheme of multiple interrupts. An interrupt request that is not accepted because of low priority will be held. If the condition following is met when the REIT instruction returns the IPL and the interrupt priority is determined, then the interrupt request being held is accepted.

Interrupt priority level of the interrupt request being held > Returned the IPL



Figure 4.6.1. Multiple interrupts

## 4.7 Precautions for Interrupts

## (1) Reading address 0000016

• When maskable interrupt is occurred, CPU read the interrupt information (the interrupt number and interrupt request level) in the interrupt sequence.

The interrupt request bit of the certain interrupt written in address 0000016 will then be set to "0".

Reading address 0000016 by software sets enabled highest priority interrupt source request bit to "0".

Though the interrupt is generated, the interrupt routine may not be executed.

Do not read address 0000016 by software.

## (2) Setting the stack pointer

The value of the stack pointer immediately after reset is initialized to 000016. Accepting an interrupt
before setting a value in the stack pointer may become a factor of runaway. Be sure to set a value in
the stack pointer before accepting an interrupt. Concerning the first instruction immediately after reset,
generating any interrupts is prohibited.

#### (3) External interrupt

- Either an "L" level or an "H" level of at least 250 ns width is necessary for the signal input to pins INTo and INT1 regardless of the CPU operation clock.
- When the polarity of the INTo and INTo pins is changed, the interrupt request bit is sometimes set to "1".
   After changing the polarity, set the interrupt request bit to "0". Figure 4.7.1 shows the procedure for changing the INT interrupt generate factor.



Figure 4.7.1. Switching condition of INT interrupt request



## (4) Rewrite the interrupt control register

• To rewrite the interrupt control register, do so at a point that does not generate the interrupt request for that register. If there is possibility of the interrupt request occur, rewrite the interrupt control register after the interrupt is disabled. The program examples are described as follow:

```
Example 1:
```

```
INT_SWITCH1:
```

FCLR I ; Disable interrupts.

AND.B #00h, 0055h; Clear TA0IC int. priority level and int. request bit.

NOP ; Four NOP instructions are required when using HOLD function.

NOP

FSET I ; Enable interrupts.

#### Example 2:

INT\_SWITCH2:

FCLR I ; Disable interrupts.

AND.B #00h, 0055h ; Clear TAOIC int. priority level and int. request bit.

MOV.W MEM, R0 ; Dummy read. FSET I ; Enable interrupts.

#### Example 3:

INT\_SWITCH3:

PUSHC FLG ; Push Flag register onto stack

FCLR I ; Disable interrupts.

AND.B #00h, 0055h ; Clear TA0IC int. priority level and int. request bit.

POPC FLG ; Enable interrupts.

The reason why two NOP instructions (four when using the HOLD function) or dummy read are inserted before FSET I in Examples 1 and 2 is to prevent the interrupt enable flag I from being set before the interrupt control register is rewritten due to effects of the instruction queue.

When a instruction to rewrite the interrupt control register is executed but the interrupt is disabled, the
interrupt request bit is not set sometimes even if the interrupt request for that register has been generated. This will depend on the instruction. If this creates problems, use the below instructions to change
the register.

Instructions: AND, OR, BCLR, BSET

# Chapter 5

**Standard Characteristics** 

## 5.1 Standard DC Characteristics

The standard characteristics given in this section are examples of M30201M4-XXXFP. The contents of these examples cannot be guaranteed. For standardized values, see "Electric characteristics".

## **5.1.1 Standard Ports Characteristics**

Figures 5.1.1 through 5.1.6 show the standard ports characteristics.



Figure 5.1.1. IOH - VOH standard characteristics of ports P0 to P7 (VCC = 5V)



Figure 5.1.2. IOL - VOL standard characteristics of ports P0 to P7 (VCC = 5V)



Figure 5.1.3. IoL - Vol standard characteristics of port P1 (Vcc = 5V, HIGH POWER)



Figure 5.1.4. IOH - VOH standard characteristics of ports P0 to P7 (VCC = 3V)



Figure 5.1.5. IoL - Vol standard characteristics of ports P0 to P7 (Vcc = 3V)



Figure 5.1.6. IoL - Vol standard characteristics of port P1 (Vcc = 3V, HIGH POWER)

## 5.1.2 Standard Characteristics of Icc-f(XIN)

Figures 5.1.7 and 5.1.8 show the standard characteristics of Icc-f(XIN). The standard characteristics given in this section are examples of M30201M4-XXXFP. The contents of these examples cannot be guaranteed. For standardized values, see "Electric characteristics".



Figures 5.1.7. Standard characteristics of Icc-f(XIN) (Vcc = 5V)



Figures 5.1.8. Standard characteristics of Icc-f(XIN) (Vcc = 3V)

## 5.2 Standard Characteristics of Pull-Up Resistor

Figure 5.2.1 shows an example of the standard characteristics of the pull-up resistor. The standard characteristics given in this section are examples of M30201M4-XXXFP. The contents of these examples cannot be guaranteed. For standardized values, see "Electric characteristics".



Figure 5.2.1. Example of the standard characteristics of the pull-up resistor

## 5.3 Standard DC Characteristics (Flash memory version)

The standard characteristics given in this section are examples of M30201F6FP. The contents of these examples cannot be guaranteed. For standardized values, see "Electric characteristics".

## 5.3.1 Standard Ports Characteristics

Figures 5.3.1 through 5.3.3 show the standard ports characteristics.





Figure 5.3.1. IOH - VOH standard characteristics of ports P0 to P7 (VCC = 5V)



Figure 5.3.2. IOL - VOL standard characteristics of ports P0 to P7 (VCC = 5V)



Figure 5.3.3. IoL - Vol standard characteristics of port P1 (Vcc = 5V, HIGH POWER)



## 5.3.2 Standard Characteristics of Icc-f(XIN)

Figure 5.3.4 shows the Characteristics of Icc-f(XIN). The standard characteristics given in this section are examples of M30201F6FP. The contents of these examples cannot be guaranteed. For standardized values, see "Electric characteristics".



Figures 5.3.4. Standard characteristics of ICC-f(XIN) (VCC = 5V)



## 5.4 Standard Characteristics of Pull-Up Resistor

Figure 5.4.1 shows an example of the standard characteristics of the pull-up resistor. The standard characteristics given in this section are examples of M30201F6FP. The contents of these examples cannot be guaranteed. For standardized values, see "Electric characteristics".



Figure 5.4.1. Example of the standard characteristics of the pull-up resistor



## Appendix 1 Check Sheet

The following check sheet was created based on items which had been the source of problems in the past. We recommend you refer to the check sheet when troubleshooting.

| Checks regarding register initial settings                                                                                                                       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ☐ Has the initial setting been made in the interrupt stack pointer (ISP) at the top of the program?                                                              |
| ☐ Has the initial setting been made in the user stack pointer (USP)? (Only if using the USP)                                                                     |
| ☐ Does the USP overlap the ISP area? (Only if using the USP)                                                                                                     |
| ☐ Is interrupt enabled after setting the ISP and USP?                                                                                                            |
| ☐ Is the top address of the variable interrupt vector table set in the interrupt table register (INTB)?                                                          |
| ☐ Is interrupt enabled after setting the INTB?                                                                                                                   |
| ☐ Has the initial setting been made in the frame base register (FB)? (Only if using the FB)                                                                      |
| ☐ Has the initial setting been made in the stack base register (SB)? (Only if using the SB)                                                                      |
| Checks regarding the internal memory  ☐ Does the RAM capacity used in the program exceed the RAM capacity of the microcomputer?                                  |
| ☐ Does the ROM capacity used in the program exceed the ROM capacity of the microcomputer?                                                                        |
| Checks regarding the protect register                                                                                                                            |
| ☐ Is writing enabled in the protect register (address 000A16) before writing in the system clock control register (addresses 000616 and 000716)?                 |
| ☐ Is writing enabled in the protect register before writing in the processor mode register (addresses 000416 and 000516)?                                        |
| ☐ Is writing enabled in the protect register before writing in the port P4 direction register (address 03EA16)?                                                  |
| ☐ Is writing effectuated in the port P4 direction register by the next instruction after writing is enabled in the protect register?                             |
| Does not an interrupt generate between the instruction writing is enabled in the protect register and the instruction writing in the port P4 direction register? |



| Checks regarding the timer                                                                                                              |
|-----------------------------------------------------------------------------------------------------------------------------------------|
| ☐ Is the timer started after a value is set in the timer register?                                                                      |
| Checks regarding low power consumption                                                                                                  |
| ☐ In the low power consumption mode, does not current flow from Vref when the Vref connection bit (bit 5 in address 03D716) is set?     |
| ☐ Is not voltage level of port floating in the low power consumption mode?                                                              |
| Checks regarding Interrupt                                                                                                              |
| ☐ When rewrite the interrupt register, do so at a point that does not generate the interruput request?                                  |
| Checks regarding low voltage                                                                                                            |
| ☐ When using at low voltage, have you checked recommended operating conditions and changed the wait bit (address 000516, bit 7) to "1"? |
| Checks regarding A-D converter                                                                                                          |
| ☐ Have you selected other than fAD (no dividing) for ØAD when using the A-D converter at VCC = 2.7 - 4.0V?                              |
| Have you selected no sample & hold function when using the A-D converter at Vcc = 2.7 - 4.0V?                                           |
| $\square$ Have you selected 8-bit mode when using the A-D converter at VCC = 2.7 - 4.0V?                                                |

## Appendix 2 Hexadecimal instruction CODE table

|          | D7 to D4 | 0000          | 0001          | 0010          | 0011          | 0100     | 0101     | 0110    | 0111     |
|----------|----------|---------------|---------------|---------------|---------------|----------|----------|---------|----------|
| D3 to D0 |          | 0             | 1             | 2             | 3             | 4        | 5        | 6       | 7        |
| 0000     | 0        | BRK           | AND.B:S       | ADD.B:S       | MOV.B:S       | BCLR:S   | BNOT:S   | JMP.S   | MULU.B   |
|          |          |               | R0H,R0L       | R0H,R0L       | R0H,A0        | 0,11[SB] | 0,11[SB] | label   | src,dest |
| 0001     | 1        | MOV.B:S       | AND.B:S       | ADD.B:S       | MOV.B:S       | BCLR:S   | BNOT:S   | JMP.S   | MULU.W   |
|          |          | R0L,dsp:8[SB] | dsp:8[SB],R0L | dsp:8[SB],R0L | dsp:8[SB],A0  | 1,11[SB] | 1,11[SB] | label   | src,dest |
| 0010     | 2        | MOV.B:S       | AND.B:S       | ADD.B:S       | MOV.B:S       | BCLR:S   | BNOT:S   | JMP.S   | MOV.B:G  |
|          |          | R0L,dsp:8[FB] | dsp:8[FB],R0L | dsp:8[FB],R0L | dsp:8[FB],A0  | 2,11[SB] | 2,11[SB] | label   | src,dest |
| 0011     | 3        | MOV.B:S       | AND.B:S       | ADD.B:S       | MOV.B:S       | BCLR:S   | BNOT:S   | JMP.S   | MOV.W:G  |
|          |          | R0L,abs16     | abs16,R0L     | abs16,R0L     | abs16,A0      | 3,11[SB] | 3,11[SB] | label   | src,dest |
| 0100     | 4        | NOP           | AND.B:S       | ADD.B:S       | MOV.B:S       | BCLR:S   | BNOT:S   | JMP.S   | CODE_74  |
|          |          |               | R0L,R0H       | R0L,R0H       | R0Çk,A1       | 4,11[SB] | 4,11[SB] | label   |          |
| 0101     | 5        | MOV.B:S       | AND.B:S       | ADD.B:S       | MOV.B:S       | BCLR:S   | BNOT:S   | JMP.S   | CODE_75  |
|          |          | R0H,dsp:8[SB] | dsp:8[SB],R0H | dsp:8[SB],R0H | dsp:8[SB],A1  | 5,11[SB] | 5,11[SB] | label   |          |
| 0110     | 6        | MOV.B:S       | AND.B:S       | ADD.B:S       | MOV.B:S       | BCLR:S   | BNOT:S   | JMP.S   | CODE_76  |
|          |          | R0H,dsp:8[FB] | dsp:8[FB],R0H | dsp:8[FB],R0H | dsp:8[FB],A1  | 6,11[SB] | 6,11[SB] | label   |          |
| 0111     | 7        | MOV.B:S       | AND.B:S       | ADD.B:S       | MOV.B:S       | BCLR:S   | BNOT:S   | JMP.S   | CODE_77  |
|          |          | R0H,abs16     | abs16,R0H     | abs16,R0H     | abs16,A1      | 7,11[SB] | 7,11[SB] | label   |          |
| 1000     | 8        | MOV.B:S       | OR.B:S        | SUB.B:S       | CMP.B:S       | BSET:S   | BTST:S   | JGEU/C  | MUL.B    |
|          |          | R0H,R0L       | R0H,R0L       | R0H,R0L       | R0H,R0L       | 0,11[SB] | 0,11[SB] | label   | src,dest |
| 1001     | 9        | MOV.B:S       | OR.B:S        | SUB.B:S       | CMP.B:S       | BSET:S   | BTST:S   | JGTU    | MUL.W    |
|          |          | dsp:8[SB],R0L | dsp:8[SB],R0L | dsp:8[SB],R0L | dsp:8[SB],R0L | 1,11[SB] | 1,11[SB] | label   | src,dest |
| 1010     | Α        | MOV.B:S       | OR.B:S        | SUB.B:S       | CMP.B:S       | BSET:S   | BTST:S   | JEQ/Z   | CODE_7A  |
|          |          | dsp:8[FB],R0L | dsp:8[FB],R0L | dsp:8[FB],R0L | dsp:8[FB],R0L | 2,11[SB] | 2,11[SB] | label   |          |
| 1011     | В        | MOV.B:S       | OR.B:S        | SUB.B:S       | CMP.B:S       | BSET:S   | BTST:S   | JN      | CODE_7B  |
|          |          | abs16,R0L     | abs16,R0L     | abs16,R0L     | abs16,R0L     | 3,11[SB] | 3,11[SB] | label   |          |
| 1100     | С        | MOV.B:S       | OR.B:S        | SUB.B:S       | CMP.B:S       | BSET:S   | BTST:S   | JLTU/NC | CODE_7C  |
|          |          | R0L,R0H       | R0L,R0H       | R0L,R0H       | R0L,R0H       | 4,11[SB] | 4,11[SB] | label   |          |
| 1101     | D        | MOV.B:S       | OR.B:S        | SUB.B:S       | CMP.B:S       | BSET:S   | BTST:S   | JLEU    | CODE_7D  |
|          |          | dsp:8[SB],R0H | dsp:8[SB],R0H | dsp:8[SB],R0H | dsp:8[SB],R0H | 5,11[SB] | 5,11[SB] | label   |          |
| 1110     | Е        | MOV.B:S       | OR.B:S        | SUB.B:S       | CMP.B:S       | BSET:S   | BTST:S   | JNE/JNZ | CODE_7E  |
|          |          | dsp:8[FB],R0H | dsp:8[FB],R0H | dsp:8[FB],R0H | dsp:8[FB],R0H | 6,11[SB] | 6,11[SB] | label   |          |
| 1111     | F        | MOV.B:S       | OR.B:S        | SUB.B:S       | CMP.B:S       | BSET:S   | BTST:S   | JPZ     |          |
|          |          | abs16,R0H     | abs16,R0H     | abs16,R0H     | abs16,R0H     | 7,11[SB] | 7,11[SB] | label   |          |

The next instruction is arranged in each CODE.

CODE\_74:STE,MOV,PUSH,NEG,ROT,NOT,LDE,POP,SHL,SHA

 ${\tt CODE\_75:STE,MOV,PUSH,NEG,ROT,NOT,LDE,POP,SHL,SHA}$ 

CODE\_76:TST,XOR,AND,OR,ADD,SUB,ADC,SBB,CMP,DIVX,ROLC,RORC,DIVU,DIV,ADCF,ABS

CODE\_77:TST,XOR,AND,OR,ADD,SUB,ADC,SBB,CMP,DIVX,ROLC,RORC,DIVU,DIV,ADCF,ABS

CODE\_7A:XCHG,LDC

CODE\_7B:XCHG,STC

 $\label{localization} $$\operatorname{CODE\_TC:MOV}$\ \textit{Dir}\ ,$\operatorname{MULU,MUL,EXTS,STC,DIVU,DIV,PUSH,DIVX,DADD,DSUB,DADC,DSBB,SMOVF,SMOVB,SSTR,ADD,LDCTX,RMPA,ENTER \\ $\operatorname{CODE\_TD:JMPI,JSRI,MULU,MUL,PUSHA,LDIPL,ADD,J}$\ \ \textit{Cnd}\ ,$\operatorname{BMCnd}\ ,$\operatorname{DIVU,DIV,PUSH,DIVX,DADD,DSUB,DADC,DSBB,SMOVF,SMOVB,SSTR,STCTX,RMPA,EXITD,WAIT}$$ 

 ${\tt CODE\_7E:BTSTC,BM}\ \textit{Cnd}\ , {\tt BNTST,BAND,BNAND,BOR,BNOR,BCLR,BSET,BNOT,BTST,BXOR,BNXOR}$ 

CODE\_EB:SHL,FSET,FCLR,MOVA,LDC,SHA,PUSHC,POPC,INT

## Appendix 2 Hexadecimal instruction CODE table

|          | D7 to D4 | 1000            | 1001            | 1010      | 1011         | 1100            | 1101                  | 1110            | 1111            |
|----------|----------|-----------------|-----------------|-----------|--------------|-----------------|-----------------------|-----------------|-----------------|
| D3 to D0 | B7 10 B1 | 8               | 9               | A         | В            | C               | D                     | E               | F               |
| 0000     | 0        | TST.B           | AND.B:G         | ADD.B:G   | ADC.B        | CMP.B:G         | CMP.B:Q               | ROT.B           | SHA.B           |
|          |          | src,dest        | src,dest        | src,dest  | src,dest     | src,dest        | #IMM,dest             | #IMM,dest       | #IMM,dest       |
| 0001     | 1        | TST.W           | AND.W:G         | ADD.W:G   | ADC.w        | CMP.W:G         | CMP.W:Q               | ROT.W           | SHA.W           |
|          |          | src,dest        | src,dest        | src,dest  | src,dest     | src,dest        | #IMM,dest             | #IMM,dest       | #IMM,dest       |
| 0010     | 2        | PUSH.B:S        | POP.B:S         | MOV.W:S   | INC.W        | PUSH.W:S        | POP.W:S               | MOV.B:S         | DEC.W           |
|          |          | R0L             | R0L             | #IMM,A0   | A0           | A0              | A0                    | #IMM,A0         | A0              |
| 0011     | 3        | ADD.B:S         | AND.B:S         | INC.B     | MOV.B:Z      | MOV.B:S         | STNZ                  | CMP.B:S         | RTS             |
|          |          | #IMM8,R0H       | #IMM8,R0H       | R0H       | #0,R0H       | #IMM8,R0H       | #IMM8,R0H             | #IMM8,R0H       |                 |
| 0100     | 4        | ADD.B:S         | AND.B:S         | INC.B     | MOV.B:Z      | MOV.B:S         | STNZ                  | CMP.B:S         | JMP.W           |
|          |          | #IMM8,R0L       | #IMM8,R0L       | R0L       | #0,R0L       | #IMM8,R0L       | #IMM8,R0L             | #IMM8,R0L       | label           |
| 0101     | 5        | ADD.B:S         | AND.B:S         | INC.B     | MOV.B:Z      | MOV.B:S         | STNZ                  | CMP.B:S         | JSR.W           |
|          |          | #IMM8,dsp:8[SB] | #IMM8,dsp:8[SB] | dsp:8[SB] | #0,dsp:8[SB] | #IMM8,dsp:8[SB] | #IMM8,dsp:8[SB]       | #IMM8,dsp:8[SB] | label           |
| 0110     | 6        | ADD.B:S         | AND.B:S         | INC.B     | MOV.B:Z      | MOV.B:S         | STNZ                  | CMP.B:S         | INTO            |
|          |          | #IMM8,dsp:8[FB] | #IMM8,dsp:8[FB] | dsp:8[FB] | #0,dsp:8[FB] | #IMM8,dsp:8[FB] | #IMM8,dsp:8[FB]       | #IMM8,dsp:8[FB] |                 |
| 0111     | 7        | ADD.B:S         | AND.B:S         | INC.B     | MOV.B:Z      | MOV.B:S         | STNZ                  | CMP.B:S         |                 |
|          |          | #IMM8,abs16     | #IMM8,abs16     | abs16     | #0,abs16     | #IMM8,abs16     | #IMM8,abs16           | #IMM8,abs16     |                 |
| 1000     | 8        | XOR.B           | OR.B:G          | SUB.B:G   | SBB.B        | ADD.B:Q         | MOV.B:Q               | SHL.B           | ADJNZ.B         |
|          |          | src,dest        | src,dest        | src,dest  | src,dest     | #IMM,dest       | #IMM,dest             | #IMM,dest       | #IMM,dest,label |
| 1001     | 9        | XOR.W           | OR.W:G          | SUB.W:G   | SBB.W        | ADD.W:Q         | MOV.W:Q               | SHL.W           | ADJNZ.W         |
|          |          | src,dest        | src,dest        | src,dest  | src,dest     | #IMM,dest       | #IMM,dest             | #IMM,dest       | #IMM,dest,label |
| 1010     | Α        | PUSH.B:S        | POP.B:S         | MOV.W:S   | INC.W        | PUSH.W:S        | POP.W:S               | MOV.B:S         | DEC.W           |
|          |          | R0H             | R0H             | #IMM,A1   | A1           | A1              | A1                    | #IMM,A1         | A1              |
| 1011     | В        | SUB.B:S         | OR.B:S          | DEC.B     | NOT.B:S      | STZ             | STZX                  | CODE_EB         | REIT            |
|          |          | #IMM8,R0H       | #IMM8,R0H       | R0H       | R0H          | #IMM8,R0H       | #IMM8,#IMM8,R0H       |                 |                 |
| 1100     | С        | SUB.B:S         | OR.B:S          | DEC.B     | NOT.B:S      | STZ             | STZX                  | PUSHM           | JMP.A           |
|          |          | #IMM8,R0L       | #IMM8,R0L       | R0L       | R0L          | #IMM8,R0L       | #IMM8,#IMM8,R0L       | src             | label           |
| 1101     | D        | SUB.B:S         | OR.B:S          | DEC.B     | NOT.B:S      | STZ             | STZX                  | РОРМ            | JSR.A           |
|          |          | #IMM8,dsp:8[SB] | #IMM8,dsp:8[SB] | dsp:8[SB] | dsp:8[SB]    | #IMM8,dsp:8[SB] | #IMM8,#IMM8,dsp:8[SB] | dest            | label           |
| 1110     | Е        | SUB.B:S         | OR.B:S          | DEC.B     | NOT.B:S      | STZ             | STZX                  | JMPS            | JMP.B           |
|          |          | #IMM8,dsp:8[FB] | #IMM8,dsp:8[FB] | dsp:8[FB] | dsp:8[FB]    | #IMM8,dsp:8[FB] | #IMM8,#IMM8,dsp:8[FB] | #IMM8           | label           |
| 1111     | F        | SUB.B:S         | OR.B:S          | DEC.B     | NOT.B:S      | STZ             | STZX                  | JSRS            | UND             |
|          |          | #IMM8,abs16     | #IMM8,abs16     | abs16     | abs16        | #IMM8,abs16     | #IMM8,#IMM8,abs16     | #IMM8           |                 |

MITSUBISHI Single-Chip Microcomputer User's Manual M30201 Group REV.B

Mar. First Edition 1999
May. Second Edition 1999
Editioned by
Committee of editing of Mitsubishi Semiconductor USER'S MANUAL

Published by Mitsubishi Electric Corp., Kitaitami Works

This book, or parts thereof, may not be reproduced in any form without permission of Mitsubishi Electric Corporation.

©1999 MITSUBISHI ELECTRIC CORPORATION