

# RX110 Group

User's Manual: Hardware

RENESAS 32-Bit MCU RX Family / RX100 Series

All information contained in these materials, including products and product specifications, represents information on the product at the time of publication and is subject to change by Renesas Electronics Corp. without notice. Please review the latest information published by Renesas Electronics Corp. through various means, including the Renesas Electronics Corp. website (http://www.renesas.com).

#### Notice

- Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information.
- Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics
  does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages
  incurred by you resulting from errors in or omissions from the information included herein.
- 3. Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 4. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from such alteration, modification, copy or otherwise misappropriation of Renesas Electronics product.
- 5. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below.
  - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots etc.
  - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anti-crime systems; and safety equipment etc.

Renesas Electronics products are neither intended nor authorized for use in products or systems that may pose a direct threat to human life or bodily injury (artificial life support devices or systems, surgical implantations etc.), or may cause serious property damages (nuclear reactor control systems, military equipment etc.). You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application for which it is not intended. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for which the product is not intended by Renesas Electronics.

- 6. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges.
- 7. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or systems manufactured by you.
- 8. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 9. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You should not use Renesas Electronics products or technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. When exporting the Renesas Electronics products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations.
- 10. It is the responsibility of the buyer or distributor of Renesas Electronics products, who distributes, disposes of, or otherwise places the product with a third party, to notify such third party in advance of the contents and conditions set forth in this document, Renesas Electronics assumes no responsibility for any losses incurred by you or third parties as a result of unauthorized use of Renesas Electronics products.
- 11. This document may not be reproduced or duplicated in any form, in whole or in part, without prior written consent of Renesas Electronics.
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majority-owned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

#### NOTES FOR CMOS DEVICES

- (1) VOLTAGE APPLICATION WAVEFORM AT INPUT PIN: Waveform distortion due to input noise or a reflected wave may cause malfunction. If the input of the CMOS device stays in the area between VIL (MAX) and VIH (MIN) due to noise, etc., the device may malfunction. Take care to prevent chattering noise from entering the device when the input level is fixed, and also in the transition period when the input level passes through the area between VIL (MAX) and VIH (MIN).
- (2) HANDLING OF UNUSED INPUT PINS: Unconnected CMOS device inputs can be cause of malfunction. If an input pin is unconnected, it is possible that an internal input level may be generated due to noise, etc., causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using pull-up or pull-down circuitry. Each unused pin should be connected to VDD or GND via a resistor if there is a possibility that it will be an output pin. All handling related to unused pins must be judged separately for each device and according to related specifications governing the device.
- (3) PRECAUTION AGAINST ESD: A strong electric field, when exposed to a MOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop generation of static electricity as much as possible, and quickly dissipate it when it has occurred. Environmental control must be adequate. When it is dry, a humidifier should be used. It is recommended to avoid using insulators that easily build up static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work benches and floors should be grounded. The operator should be grounded using a wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with mounted semiconductor devices.
- (4) STATUS BEFORE INITIALIZATION: Power-on does not necessarily define the initial status of a MOS device. Immediately after the power source is turned ON, devices with reset functions have not yet been initialized. Hence, power-on does not guarantee output pin levels, I/O settings or contents of registers. A device is not initialized until the reset signal is received. A reset operation must be executed immediately after power-on for devices with reset functions.
- (5) POWER ON/OFF SEQUENCE: In the case of a device that uses different power supplies for the internal operation and external interface, as a rule, switch on the external power supply after switching on the internal power supply. When switching the power supply off, as a rule, switch off the external power supply and then the internal power supply. Use of the reverse power on/off sequences may result in the application of an overvoltage to the internal elements of the device, causing malfunction and degradation of internal elements due to the passage of an abnormal current. The correct power on/off sequence must be judged separately for each device and according to related specifications governing the device.
- (6) INPUT OF SIGNAL DURING POWER OFF STATE: Do not input signals or an I/O pull-up power supply while the device is not powered. The current injection that results from input of such a signal or I/O pull-up power supply may cause malfunction and the abnormal current that passes in the device at this time may cause degradation of internal elements. Input of signals during the power off state must be judged separately for each device and according to related specifications governing the device.

#### General Precautions in the Handling of Microprocessing Unit and Microcontroller Unit Products

The following usage notes are applicable to all Microprocessing unit and Microcontroller unit products from Renesas. For detailed usage notes on the products covered by this document, refer to the relevant sections of the document as well as any technical updates that have been issued for the products.

#### 1. Handling of Unused Pins

Handle unused pins in accordance with the directions given under Handling of Unused Pins in the manual

34 The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual.

#### 2. Processing at Power-on

The state of the product is undefined at the moment when power is supplied.

- 3/4 The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied.
  In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed.
  In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified.
- 3. Prohibition of Access to Reserved Addresses

Access to reserved addresses is prohibited.

3/4 The reserved addresses are provided for the possible future expansion of functions. Do not access these addresses; the correct operation of LSI is not guaranteed if they are accessed.

#### 4. Clock Signals

After applying a reset, only release the reset line after the operating clock signal has become stable. When switching the clock signal during program execution, wait until the target clock signal has stabilized.

When the clock signal is generated with an external resonator (or from an external oscillator) during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Moreover, when switching to a clock signal produced with an external resonator (or by an external oscillator) while program execution is in progress, wait until the target clock signal is stable.

#### 5. Differences between Products

Before changing from one product to another, i.e. to a product with a different part number, confirm that the change will not lead to problems.

34 The characteristics of Microprocessing unit or Microcontroller unit products in the same group but having a different part number may differ in terms of the internal memory capacity, layout pattern, and other factors, which can affect the ranges of electrical characteristics, such as characteristic values, operating margins, immunity to noise, and amount of radiated noise. When changing to a product with a different part number, implement a system-evaluation test for the given product.

# Specification Differences between Products

There are the following specification differences in these MCU products depending on the package.

 Table 1
 Specification Differences Depending on Packages

| Chapter                        |                                    | Specification Differences                                                                                        |                                                                                                                 |  |
|--------------------------------|------------------------------------|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|--|
| One                            | ipiei                              | Products with 40 pins or less                                                                                    | Products with 48 pins or more                                                                                   |  |
| 9. Clock Generation<br>Circuit | 9.7.4 Notes on<br>Sub-Clock        | Although sub-clock oscillator pins are not available, the sub-clock circuit must be initialized at a cold start. | At a cold start, initialize the sub-clock control circuit regardless of whether the sub-clock is in use or not. |  |
| 17. I/O Ports                  | 17.3.4 Port Mode<br>Register (PMR) | Set the PORTH.PMR.B7 bit to 1.                                                                                   | No processing is required.                                                                                      |  |

# How to Use This Manual

## 1. Objective and Target Users

This manual was written to explain the hardware functions and electrical characteristics of this LSI to the target users, i.e. those who will be using this LSI in the design of application systems. Target users are expected to understand the fundamentals of electrical circuits, logic circuits, and microcomputers.

This manual is organized in the following items: an overview of the product, descriptions of the CPU, system control functions, and peripheral functions, electrical characteristics of the device, and usage notes.

When designing an application system that includes this LSI, take all points to note into account. Points to note are given in their contexts and at the final part of each section, and in the section giving usage notes.

The list of revisions is a summary of major points of revision or addition for earlier versions. It does not cover all revised items. For details on the revised points, see the actual locations in the manual.

The following documents have been prepared for the RX110 Group. Before using any of the documents, please visit our website to verify that you have the most up-to-date available version of the document.

| Document Type               | Contents                                                                                                                                                       | Document Title                            | Document No.  |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|---------------|
| Datasheet                   | Overview of hardware and electrical characteristics                                                                                                            | RX110 Group<br>Datasheet                  | R01DS0202EJ   |
| User's Manual:<br>Hardware  | Hardware specifications (pin assignments, memory maps, peripheral specifications, electrical characteristics, and timing charts) and descriptions of operation | RX110 Group<br>User's Manual:<br>Hardware | This document |
| User's Manual:<br>Software  | Detailed descriptions of the CPU and instruction set                                                                                                           | RX Family<br>User's Manual:<br>Software   | R01US0032EJ   |
| Application Note            | Examples of applications and sample programs                                                                                                                   | _                                         | _             |
| Renesas Technical<br>Update | Preliminary report on the specifications of a product, document, etc.                                                                                          | _                                         | _             |

## 2. Description of Registers

Each register description includes a bit chart, illustrating the arrangement of bits, and a table of bits, describing the meanings of the bit settings. The standard format and notation for bit charts and tables are described below.



(1) R/W: The bit or field is readable and writable.

R/(W): The bit or field is readable and writable. However, writing to this bit or field has some

limitations. For details on the limitations, see the description or notes of respective registers.

R: The bit or field is readable. Writing to this bit or field has no effect.

(2) Reserved.

Use the specified value when writing to this bit or field; otherwise, the correct operation is not guaranteed.

(3) Setting prohibited. The correct operation is not guaranteed if such a setting is performed.

# 3. List of Abbreviations and Acronyms

| Abbreviation | Full Form                                     |
|--------------|-----------------------------------------------|
| ACIA         | Asynchronous Communications Interface Adapter |
| bps          | bits per second                               |
| CRC          | Cyclic Redundancy Check                       |
| DMA          | Direct Memory Access                          |
| DMAC         | Direct Memory Access Controller               |
| GSM          | Global System for Mobile Communications       |
| Hi-Z         | High Impedance                                |
| IEBus        | Inter Equipment Bus                           |
| I/O          | Input/Output                                  |
| IrDA         | Infrared Data Association                     |
| LSB          | Least Significant Bit                         |
| MSB          | Most Significant Bit                          |
| NC           | Non-Connect                                   |
| PLL          | Phase Locked Loop                             |
| PWM          | Pulse Width Modulation                        |
| SIM          | Subscriber Identity Module                    |
| UART         | Universal Asynchronous Receiver/Transmitter   |
| VCO          | Voltage Controlled Oscillator                 |

All trademarks and registered trademarks are the property of their respective owners.

 $SuperFlash^{\circledR} is \ a \ registered \ trademark \ of \ Silicon \ Storage \ Technology, Inc. \ in \ several \ countries \ including \ the \ United \ States \ and \ Japan.$ 

# Contents

| Fe | eatures  |                                                                                   | 32 |
|----|----------|-----------------------------------------------------------------------------------|----|
| 1. | Overview |                                                                                   | 33 |
|    | 1.1 Out  | tline of Specifications                                                           | 33 |
|    | 1.2 Lis  | t of Products                                                                     | 37 |
|    | 1.3 Blo  | ck Diagram                                                                        | 40 |
|    | 1.4 Pin  | Functions                                                                         | 41 |
|    | 1.5 Pin  | Assignments                                                                       | 44 |
| 2. | CPU      |                                                                                   | 57 |
|    | 2.1 Fea  | tures                                                                             | 57 |
|    | 2.2 Reg  | gister Set of the CPU                                                             | 58 |
|    | 2.2.1    | General-Purpose Registers (R0 to R15)                                             | 59 |
|    | 2.2.2    | Control Registers                                                                 | 59 |
|    | 2.2.2.1  | Interrupt Stack Pointer (ISP)/User Stack Pointer (USP)                            | 60 |
|    | 2.2.2.2  | 2 Interrupt Table Register (INTB)                                                 | 60 |
|    | 2.2.2.3  | Program Counter (PC)                                                              | 60 |
|    | 2.2.2.4  | Processor Status Word (PSW)                                                       | 61 |
|    | 2.2.2.5  | Backup PC (BPC)                                                                   | 62 |
|    | 2.2.2.6  | Backup PSW (BPSW)                                                                 | 63 |
|    | 2.2.2.7  | Fast Interrupt Vector Register (FINTV)                                            | 63 |
|    | 2.2.3    | Register Associated with DSP Instructions                                         | 63 |
|    | 2.2.3.1  | Accumulator (ACC)                                                                 | 63 |
|    | 2.3 Pro  | cessor Mode                                                                       | 64 |
|    | 2.3.1    | Supervisor Mode                                                                   | 64 |
|    | 2.3.2    | User Mode                                                                         | 64 |
|    | 2.3.3    | Privileged Instruction                                                            | 64 |
|    | 2.3.4    | Switching between Processor Modes                                                 | 64 |
|    | 2.4 Dat  | a Types                                                                           | 65 |
|    | 2.5 Enc  | lian                                                                              | 65 |
|    | 2.5.1    | Switching the Endian                                                              | 65 |
|    | 2.5.2    | Access to I/O Registers                                                           | 69 |
|    | 2.5.3    | Notes on Access to I/O Registers                                                  | 69 |
|    | 2.5.4    | Data Arrangement                                                                  | 69 |
|    | 2.5.4.1  | Data Arrangement in Registers                                                     | 69 |
|    | 2.5.4.2  | Data Arrangement in Memory                                                        | 70 |
|    | 2.5.5    | Notes on the Allocation of Instruction Codes                                      |    |
|    | 2.6 Vec  | ctor Table                                                                        | 71 |
|    | 2.6.1    | Fixed Vector Table                                                                |    |
|    | 2.6.2    | Relocatable Vector Table                                                          |    |
|    | •        | eration of Instructions                                                           |    |
|    | 2.7.1    | Data Prefetching by the RMPA Instruction and the String-Manipulation Instructions | 73 |
|    | 2.8 Pip  | eline                                                                             | 73 |

|    | 2.8.1     | Overview                                                                        | 73  |
|----|-----------|---------------------------------------------------------------------------------|-----|
|    | 2.8.2     | Instructions and Pipeline Processing                                            | 75  |
|    | 2.8.2.    | Instructions Converted into Single Micro-Operation and Pipeline Processing      | 75  |
|    | 2.8.2.    | 2 Instructions Converted into Multiple Micro-Operations and Pipeline Processing | 77  |
|    | 2.8.2.    | Pipeline Basic Operation                                                        | 80  |
|    | 2.8.3     | Calculation of the Instruction Processing Time                                  | 82  |
|    | 2.8.4     | Numbers of Cycles for Response to Interrupts                                    | 83  |
| 3. | Operating | g Modes                                                                         | 84  |
|    | 3.1 Op    | erating Mode Types and Selection                                                | 84  |
|    | 3.2 Re    | gister Descriptions                                                             | 85  |
|    | 3.2.1     | Mode Monitor Register (MDMONR)                                                  | 85  |
|    | 3.2.2     | System Control Register 1 (SYSCR1)                                              | 86  |
|    | 3.3 De    | tails of Operating Modes                                                        | 87  |
|    | 3.3.1     | Single-Chip Mode                                                                | 87  |
|    | 3.3.2     | Boot Mode                                                                       | 87  |
|    | 3.3.2.    | 1 Boot Mode (SCI)                                                               | 87  |
|    | 3.4 Tra   | ansitions of Operating Modes                                                    | 87  |
|    | 3.4.1     | MD Pin Levels and Operating Mode Transitions                                    | 87  |
| 4. | Address   | Space                                                                           | 88  |
|    | 4.1 Ad    | dress Space                                                                     | 88  |
| 5. | I/O Regis | sters                                                                           | 90  |
|    | 5.1 I/C   | Register Addresses (Address Order)                                              | 92  |
| 6. | Resets    |                                                                                 | 105 |
|    | 6.1 Ov    | erview                                                                          | 105 |
|    | 6.2 Re    | gister Descriptions                                                             | 107 |
|    | 6.2.1     | Reset Status Register 0 (RSTSR0)                                                | 107 |
|    | 6.2.2     | Reset Status Register 1 (RSTSR1)                                                | 108 |
|    | 6.2.3     | Reset Status Register 2 (RSTSR2)                                                | 109 |
|    | 6.2.4     | Software Reset Register (SWRR)                                                  | 110 |
|    | 6.3 Op    | eration                                                                         | 111 |
|    | 6.3.1     | RES# Pin Reset                                                                  | 111 |
|    | 6.3.2     | Power-On Reset                                                                  | 111 |
|    | 6.3.3     | Voltage Monitoring 1 Reset and Voltage Monitoring 2 Reset                       | 113 |
|    | 6.3.4     | Independent Watchdog Timer Reset                                                | 114 |
|    | 6.3.5     | Software Reset                                                                  | 115 |
|    | 6.3.6     | Determination of Cold/Warm Start                                                | 115 |
|    | 6.3.7     | Determination of Reset Generation Source                                        | 116 |
| 7. | Option-S  | etting Memory                                                                   | 117 |
|    | 7.1 Ov    | erview                                                                          | 117 |
|    | 7.2 Re    | gister Descriptions                                                             | 118 |
|    | 7.2.1     | Option Function Select Register 0 (OFS0)                                        | 118 |
|    |           |                                                                                 |     |

|    | 7.2.2  | Option Function Select Register 1 (OFS1)                              | 120 |
|----|--------|-----------------------------------------------------------------------|-----|
|    | 7.2.3  | Endian Select Register (MDE)                                          | 122 |
|    | 7.3    | Usage Note                                                            | 123 |
|    | 7.3.1  | Setting Example of Option-Setting Memory                              | 123 |
|    | 7.3.2  | Note on Parallel Use of the Voltage Monitoring 1 Reset and IWDT Reset | 123 |
| 8. | Voltag | ge Detection Circuit (LVDAa)                                          | 124 |
|    | 8.1    | Overview                                                              | 124 |
|    | 8.2    | Register Descriptions                                                 | 127 |
|    | 8.2.1  | Voltage Monitoring 1 Circuit Control Register 1 (LVD1CR1)             | 127 |
|    | 8.2.2  | Voltage Monitoring 1 Circuit Status Register (LVD1SR)                 | 128 |
|    | 8.2.3  | Voltage Monitoring 2 Circuit Control Register 1 (LVD2CR1)             | 129 |
|    | 8.2.4  | Voltage Monitoring 2 Circuit Status Register (LVD2SR)                 | 130 |
|    | 8.2.5  | Voltage Monitoring Circuit Control Register (LVCMPCR)                 | 131 |
|    | 8.2.6  | Voltage Detection Level Select Register (LVDLVLR)                     | 132 |
|    | 8.2.7  | Voltage Monitoring 1 Circuit Control Register 0 (LVD1CR0)             | 133 |
|    | 8.2.8  | Voltage Monitoring 2 Circuit Control Register 0 (LVD2CR0)             | 134 |
|    | 8.3    | VCC Input Voltage Monitor                                             | 135 |
|    | 8.3.1  | Monitoring Vdet1                                                      | 135 |
|    | 8.3.2  | Monitoring Vdet2                                                      | 135 |
|    | 8.4    | Interrupt and Reset from Voltage Monitoring 1                         | 136 |
|    | 8.5    | Interrupt and Reset from Voltage Monitoring 2                         | 138 |
| 9. | Clock  | Generation Circuit                                                    | 140 |
|    | 9.1    | Overview                                                              | 140 |
|    | 9.2    | Register Descriptions                                                 | 142 |
|    | 9.2.1  | System Clock Control Register (SCKCR)                                 | 142 |
|    | 9.2.2  | System Clock Control Register 3 (SCKCR3)                              | 144 |
|    | 9.2.3  | Main Clock Oscillator Control Register (MOSCCR)                       | 145 |
|    | 9.2.4  | Sub-Clock Oscillator Control Register (SOSCCR)                        | 146 |
|    | 9.2.5  | Low-Speed On-Chip Oscillator Control Register (LOCOCR)                | 147 |
|    | 9.2.6  | IWDT-Dedicated On-Chip Oscillator Control Register (ILOCOCR)          | 148 |
|    | 9.2.7  | High-Speed On-Chip Oscillator Control Register (HOCOCR)               | 149 |
|    | 9.2.8  | Oscillation Stabilization Flag Register (OSCOVFSR)                    | 150 |
|    | 9.2.9  | Oscillation Stop Detection Control Register (OSTDCR)                  | 151 |
|    | 9.2.10 | Oscillation Stop Detection Status Register (OSTDSR)                   | 152 |
|    | 9.2.1  | Main Clock Oscillator Wait Control Register (MOSCWTCR)                | 153 |
|    | 9.2.12 | 2 High-Speed On-Chip Oscillator Wait Control Register (HOCOWTCR)      | 154 |
|    | 9.2.13 | CLKOUT Output Control Register (CKOCR)                                | 155 |
|    | 9.2.14 | Main Clock Oscillator Forced Oscillation Control Register (MOFCR)     | 156 |
|    | 9.3    | Main Clock Oscillator                                                 | 157 |
|    | 9.3.1  | Connecting a Crystal                                                  | 157 |
|    | 9.3.2  | External Clock Input                                                  | 158 |
|    |        |                                                                       |     |

|     | 9.3.3 | Handling of Pins When the Main Clock is Not Used         | 158 |
|-----|-------|----------------------------------------------------------|-----|
|     | 9.3.4 | Notes on the External Clock Input                        | 158 |
|     | 9.4   | Sub-Clock Oscillator                                     | 159 |
|     | 9.4.1 | Connecting 32.768-kHz Crystal                            | 159 |
|     | 9.4.2 | Handling of Pins When Sub-Clock is Not Used              | 159 |
|     | 9.5   | Oscillation Stop Detection Function                      | 160 |
|     | 9.5.1 | Oscillation Stop Detection and Operation after Detection | 160 |
|     | 9.5.2 | Oscillation Stop Detection Interrupts                    | 161 |
|     | 9.6   | Internal Clock                                           | 162 |
|     | 9.6.1 | System Clock                                             | 162 |
|     | 9.6.2 | Peripheral Module Clock                                  | 162 |
|     | 9.6.3 | FlashIF Clock                                            | 162 |
|     | 9.6.4 | CAC Clock                                                | 162 |
|     | 9.6.5 | RTC-Dedicated Clock                                      | 162 |
|     | 9.6.6 | IWDT-Dedicated Clock                                     | 162 |
|     | 9.7   | Usage Notes                                              | 163 |
|     | 9.7.1 | Notes on Clock Generation Circuit                        | 163 |
|     | 9.7.2 | Notes on Resonator                                       | 163 |
|     | 9.7.3 | Notes on Board Design                                    | 163 |
|     | 9.7.4 | Notes on Sub-Clock                                       | 164 |
| 10. | Clock | Frequency Accuracy Measurement Circuit (CAC)             | 168 |
|     | 10.1  | Overview                                                 | 168 |
|     | 10.2  | Register Descriptions                                    | 170 |
|     | 10.2. | 1 CAC Control Register 0 (CACR0)                         | 170 |
|     | 10.2. | 2 CAC Control Register 1 (CACR1)                         | 171 |
|     | 10.2. | 3 CAC Control Register 2 (CACR2)                         | 172 |
|     | 10.2. | CAC Interrupt Request Enable Register (CAICR)            | 173 |
|     | 10.2. | 5 CAC Status Register (CASTR)                            | 174 |
|     | 10.2. | CAC Upper-Limit Value Setting Register (CAULVR)          | 175 |
|     | 10.2. | 7 CAC Lower-Limit Value Setting Register (CALLVR)        | 175 |
|     | 10.2. | 8 CAC Counter Buffer Register (CACNTBR)                  | 175 |
|     | 10.3  | Operation                                                | 176 |
|     | 10.3. | Measuring Clock Frequency                                | 176 |
|     | 10.3. | Digital Filtering of Signals on the CACREF Pin           | 177 |
|     | 10.4  | Interrupt Requests                                       | 177 |
|     | 10.5  | Usage Notes                                              | 178 |
|     | 10.5. | Module Stop Function Setting                             | 178 |
| 11. | Low F | Power Consumption                                        | 179 |
|     | 11.1  | Overview                                                 | 179 |
|     | 11.2  | Register Descriptions                                    | 183 |
|     | 11.2. | Standby Control Register (SBYCR)                         | 183 |
|     |       |                                                          |     |

|    | 11.2.2     | Module Stop Control Register A (MSTPCRA)                    | 184 |
|----|------------|-------------------------------------------------------------|-----|
|    | 11.2.3     | Module Stop Control Register B (MSTPCRB)                    | 185 |
|    | 11.2.4     | Module Stop Control Register C (MSTPCRC)                    | 186 |
|    | 11.2.5     | Operating Power Control Register (OPCCR)                    | 187 |
|    | 11.2.6     | Sub Operating Power Control Register (SOPCCR)               | 188 |
|    | 11.2.7     | Sleep Mode Return Clock Source Switching Register (RSTCKCR) | 193 |
|    | 11.3 Redu  | ncing Power Consumption by Switching Clock Signals          | 195 |
|    | 11.4 Mod   | ule Stop Function                                           | 195 |
|    | 11.5 Fund  | tion for Lower Operating Power Consumption                  | 195 |
|    | 11.5.1     | Setting Operating Power Control Mode                        | 195 |
|    | 11.6 Low   | Power Consumption Modes                                     | 197 |
|    | 11.6.1     | Sleep Mode                                                  | 197 |
|    | 11.6.1.1   | Entry to Sleep Mode                                         | 197 |
|    | 11.6.1.2   | Exit from Sleep Mode                                        | 198 |
|    | 11.6.1.3   | Sleep Mode Return Clock Source Switching Function           | 198 |
|    | 11.6.2     | Deep Sleep Mode                                             | 199 |
|    | 11.6.2.1   | Entry to Deep Sleep Mode                                    | 199 |
|    | 11.6.2.2   | Exit from Deep Sleep Mode                                   | 200 |
|    | 11.6.3     | Software Standby Mode                                       | 201 |
|    | 11.6.3.1   | Entry to Software Standby Mode                              | 201 |
|    | 11.6.3.2   | Exit from Software Standby Mode                             | 202 |
|    | 11.6.3.3   | Example of Software Standby Mode Application                | 203 |
|    | 11.7 Usag  | e Notes                                                     | 204 |
|    | 11.7.1     | I/O Port States                                             | 204 |
|    | 11.7.2     | Module Stop State of DTC                                    | 204 |
|    | 11.7.3     | On-Chip Peripheral Module Interrupts                        | 204 |
|    | 11.7.4     | Write Access to MSTPCRA, MSTPCRB, and MSTPCRC               | 204 |
|    | 11.7.5     | Timing of WAIT Instructions                                 | 204 |
|    | 11.7.6     | Rewrite the Register by DTC in Sleep Mode                   | 204 |
| 2. | Register W | rite Protection Function                                    | 205 |
|    | •          | ster Descriptions                                           |     |
|    | 12.1.1     | Protect Register (PRCR)                                     |     |
| 3. | Exception  | Handling                                                    |     |
| Ο. | -          | ption Events                                                |     |
|    | 13.1.1     | Undefined Instruction Exception                             |     |
|    | 13.1.2     | Privileged Instruction Exception                            |     |
|    | 13.1.3     | Reset                                                       |     |
|    | 13.1.4     | Non-Maskable Interrupt                                      |     |
|    | 13.1.5     | Interrupts                                                  |     |
|    | 13.1.6     | Unconditional Trap                                          |     |
|    |            | ption Handling Procedure                                    |     |
|    | DACC       | F                                                           |     |

| 13.3 Ac       | ceptance of Exception Events                                            | 211 |
|---------------|-------------------------------------------------------------------------|-----|
| 13.3.1        | Acceptance Timing and Saved PC Value                                    | 211 |
| 13.3.2        | Vector and Site for Saving the Values in the PC and PSW                 | 211 |
| 13.4 Ha       | rdware Processing for Accepting and Returning from Exceptions           | 212 |
| 13.5 Ha       | rdware Pre-Processing                                                   | 213 |
| 13.5.1        | Undefined Instruction Exception                                         | 213 |
| 13.5.2        | Privileged Instruction Exception                                        | 213 |
| 13.5.3        | Reset                                                                   | 213 |
| 13.5.4        | Non-Maskable Interrupt                                                  | 213 |
| 13.5.5        | Interrupt                                                               | 214 |
| 13.5.6        | Unconditional Trap                                                      | 214 |
| 13.6 Res      | turn from Exception Handling Routine                                    | 215 |
| 13.7 Pri      | ority of Exception Events                                               | 215 |
| 14. Interrupt | Controller (ICUb)                                                       | 216 |
| 14.1 Ov       | rerview                                                                 | 216 |
| 14.2 Re       | gister Descriptions                                                     | 218 |
| 14.2.1        | Interrupt Request Register n (IRn) (n = interrupt vector number)        | 218 |
| 14.2.2        | Interrupt Request Enable Register m (IERm) (m = 02h to 1Fh)             | 219 |
| 14.2.3        | Interrupt Source Priority Register n (IPRn) (n = 000 to 249)            | 220 |
| 14.2.4        | Fast Interrupt Set Register (FIR)                                       | 221 |
| 14.2.5        | Software Interrupt Activation Register (SWINTR)                         | 222 |
| 14.2.6        | DTC Activation Enable Register n (DTCERn) (n = interrupt vector number) | 223 |
| 14.2.7        | IRQ Control Register i (IRQCRi) (i = 0 to 7)                            | 224 |
| 14.2.8        | IRQ Pin Digital Filter Enable Register 0 (IRQFLTE0)                     | 225 |
| 14.2.9        | IRQ Pin Digital Filter Setting Register 0 (IRQFLTC0)                    | 226 |
| 14.2.10       | Non-Maskable Interrupt Status Register (NMISR)                          | 227 |
| 14.2.11       | Non-Maskable Interrupt Enable Register (NMIER)                          | 229 |
| 14.2.12       | Non-Maskable Interrupt Status Clear Register (NMICLR)                   | 230 |
| 14.2.13       | NMI Pin Interrupt Control Register (NMICR)                              | 231 |
| 14.2.14       | NMI Pin Digital Filter Enable Register (NMIFLTE)                        | 231 |
| 14.2.15       | NMI Pin Digital Filter Setting Register (NMIFLTC)                       | 232 |
| 14.3 Ve       | ctor Table                                                              | 233 |
| 14.3.1        | Interrupt Vector Table                                                  | 233 |
| 14.3.2        | Fast Interrupt Vector Table                                             | 241 |
| 14.3.3        | Non-maskable Interrupt Vector Table                                     | 241 |
| 14.4 Into     | errupt Operation                                                        | 241 |
| 14.4.1        | Detecting Interrupts                                                    | 241 |
| 14.4.1        | .1 Operation of Status Flags for Edge-Detected Interrupts               | 241 |
| 14.4.1        | Operation of Status Flags for Level-Detected Interrupts                 | 243 |
| 14.4.2        | Enabling and Disabling Interrupt Sources                                | 244 |
| 14.4.3        | Selecting Interrupt Request Destinations                                | 244 |
|               |                                                                         |     |

| 14.4     | .4 Determining Priority                                   | 245 |
|----------|-----------------------------------------------------------|-----|
| 14.4     | Multiple Interrupts                                       | 245 |
| 14.4     | .6 Fast Interrupt                                         | 246 |
| 14.4     | .7 Digital Filter                                         | 246 |
| 14.4     | .8 External Pin Interrupts                                | 247 |
| 14.5     | Non-maskable Interrupt Operation                          | 248 |
| 14.6     | Return from Power-Down States                             | 249 |
| 14.6     | Return from Sleep Mode or Deep Sleep Mode                 | 249 |
| 14.6     | Return from Software Standby Mode                         | 249 |
| 14.7     | Usage Note                                                | 249 |
| 14.7     | Note on WAIT Instruction Used with Non-Maskable Interrupt | 249 |
| 15. Buse | 98                                                        | 250 |
| 15.1     | Overview                                                  | 250 |
| 15.2     | Description of Buses                                      | 252 |
| 15.2     | 2.1 CPU Buses                                             | 252 |
| 15.2     | 2.2 Memory Buses                                          | 252 |
| 15.2     | 2.3 Internal Main Buses                                   | 252 |
| 15.2     | 2.4 Internal Peripheral Buses                             | 253 |
| 15.2     | 2.5 Write Buffer Function (Internal Peripheral Bus)       | 254 |
| 15.2     | 2.6 Parallel Operation                                    | 255 |
| 15.2     | 2.7 Restrictions                                          | 255 |
| 15.3     | Register Descriptions                                     | 256 |
| 15.3     | Bus Error Status Clear Register (BERCLR)                  | 256 |
| 15.3     | Bus Error Monitoring Enable Register (BEREN)              | 256 |
| 15.3     | Bus Error Status Register 1 (BERSR1)                      | 257 |
| 15.3     | Bus Error Status Register 2 (BERSR2)                      | 257 |
| 15.3     | Bus Priority Control Register (BUSPRI)                    | 258 |
| 15.4     | Bus Error Monitoring Section                              | 260 |
| 15.4     | 1.1 Type of Bus Error                                     | 260 |
| 1        | 15.4.1.1 Illegal Address Access                           | 260 |
| 1        | 15.4.1.2 Timeout                                          | 260 |
| 15.4     | Operations When a Bus Error Occurs                        | 260 |
| 15.4     | Conditions Leading to Bus Errors                          | 261 |
| 16. Data | a Transfer Controller (DTCa)                              | 262 |
| 16.1     | Overview                                                  | 262 |
| 16.2     | Register Descriptions                                     | 264 |
| 16.2     | DTC Mode Register A (MRA)                                 | 264 |
| 16.2     | DTC Mode Register B (MRB)                                 | 265 |
| 16.2     | DTC Transfer Source Register (SAR)                        | 266 |
| 16.2     | DTC Transfer Destination Register (DAR)                   | 266 |
| 16.2     | 2.5 DTC Transfer Count Register A (CRA)                   | 267 |

| 16      | 5.2.6 DTC Transfer Count Register B (CRB)            | 268 |
|---------|------------------------------------------------------|-----|
| 16      | 5.2.7 DTC Control Register (DTCCR)                   | 268 |
| 16      | 5.2.8 DTC Vector Base Register (DTCVBR)              | 269 |
| 16      | 5.2.9 DTC Address Mode Register (DTCADMOD)           | 269 |
| 16      | 5.2.10 DTC Module Start Register (DTCST)             | 270 |
| 16      | 5.2.11 DTC Status Register (DTCSTS)                  | 271 |
| 16.3    | Activation Sources                                   | 272 |
| 16      | Allocating Transfer Information and DTC Vector Table | 272 |
| 16.4    | Operation                                            | 274 |
| 16      | 5.4.1 Transfer Information Read Skip Function        | 276 |
| 16      | 5.4.2 Transfer Information Write-Back Skip Function  | 277 |
| 16      | 5.4.3 Normal Transfer Mode                           | 278 |
| 16      | 6.4.4 Repeat Transfer Mode                           | 279 |
| 16      | 5.4.5 Block Transfer Mode                            | 280 |
| 16      | 5.4.6 Chain Transfer                                 | 281 |
| 16      | 5.4.7 Operation Timing                               | 282 |
| 16      | Execution Cycles of the DTC                          | 285 |
| 16      | 5.4.9 DTC Bus Mastership Release Timing              | 285 |
| 16.5    | DTC Setting Procedure                                | 286 |
| 16.6    | Examples of DTC Usage                                | 287 |
| 16      | 6.6.1 Normal Transfer                                | 287 |
| 16      | 6.6.2 Chain Transfer When the Counter = 0            | 288 |
| 16.7    | Interrupt Source                                     | 289 |
| 16.8    | Low Power Consumption Function                       | 290 |
| 16.9    | Usage Notes                                          | 291 |
| 16      | 7.9.1 Transfer Information Start Address             | 291 |
| 16      | 5.9.2 Allocating Transfer Information                | 291 |
| 17. I/O | Ports                                                | 292 |
| 17.1    | Overview                                             | 292 |
| 17.2    | I/O Port Configuration                               | 294 |
| 17.3    | Register Descriptions                                | 298 |
| 17      | .3.1 Port Direction Register (PDR)                   | 298 |
| 17      | .3.2 Port Output Data Register (PODR)                | 299 |
| 17      | .3.3 Port Input Data Register (PIDR)                 | 300 |
| 17      | .3.4 Port Mode Register (PMR)                        | 301 |
| 17      | .3.5 Open Drain Control Register 0 (ODR0)            | 302 |
| 17      | .3.6 Open Drain Control Register 1 (ODR1)            | 303 |
| 17      | .3.7 Pull-Up Control Register (PCR)                  | 304 |
| 17      | .3.8 Port Switching Register A (PSRA)                | 305 |
| 17      | .3.9 Port Switching Register B (PSRB)                | 306 |
| 17.4    | Initialization of the Port Direction Register (PDR)  | 307 |

|     | 17.5 H   | andling of Unused Pins                                           | 309 |
|-----|----------|------------------------------------------------------------------|-----|
| 18. | Multi-Fu | nction Pin Controller (MPC)                                      | 310 |
|     | 18.1 O   | verview                                                          | 310 |
|     | 18.2 R   | egister Descriptions                                             | 315 |
|     | 18.2.1   | Write-Protect Register (PWPR)                                    | 315 |
|     | 18.2.2   | P1n Pin Function Control Register (P1nPFS) (n = 4 to 7)          | 316 |
|     | 18.2.3   | P2n Pin Function Control Register (P2nPFS) (n = 6 to 7)          | 318 |
|     | 18.2.4   | P3n Pin Function Control Register (P3nPFS) (n = 0 to 2)          | 319 |
|     | 18.2.5   | P4n Pin Function Control Register (P4nPFS) (n = 0 to 4, 6)       | 320 |
|     | 18.2.6   | PAn Pin Function Control Register (PAnPFS) (n = 0, 1, 3, 4, 6)   | 321 |
|     | 18.2.7   | PBn Pin Function Control Register (PBnPFS) (n = 0, 1, 3, 5 to 7) | 324 |
|     | 18.2.8   | PCn Pin Function Control Register (PCnPFS) (n = 2 to 7)          | 326 |
|     | 18.2.9   | PEn Pin Function Control Register (PEnPFS) (n = 0 to 7)          | 328 |
|     | 18.2.10  | PHn Pin Function Control Register (PHnPFS) (n = 0 to 3)          | 330 |
|     | 18.2.11  | PJn Pin Function Control Register (PJnPFS) (n = 6, 7)            | 331 |
|     | 18.3 U   | sage Notes                                                       | 332 |
|     | 18.3.1   | Procedure for Specifying I/O Pin Functions                       | 332 |
|     | 18.3.2   | Notes on MPC Register Setting                                    | 332 |
|     | 18.3.3   | Note on Using Analog Functions                                   | 333 |
| 19. | Multi-Fu | nction Timer Pulse Unit 2 (MTU2b)                                | 334 |
|     | 19.1 O   | verview                                                          | 334 |
|     | 19.2 R   | egister Descriptions                                             | 338 |
|     | 19.2.1   | Timer Control Register (TCR)                                     | 338 |
|     | 19.2.2   | Timer Mode Register (TMDR)                                       | 341 |
|     | 19.2.3   | Timer I/O Control Register (TIOR)                                | 343 |
|     | 19.2.4   | Timer Compare Match Clear Register (TCNTCMPCLR)                  | 349 |
|     | 19.2.5   | Timer Interrupt Enable Register (TIER)                           | 350 |
|     | 19.2.6   | Timer Status Register (TSR)                                      | 352 |
|     | 19.2.7   | Timer Buffer Operation Transfer Mode Register (TBTM)             | 353 |
|     | 19.2.8   | Timer Input Capture Control Register (TICCR)                     | 354 |
|     | 19.2.9   | Timer Counter (TCNT)                                             | 354 |
|     | 19.2.10  | Timer General Register (TGR)                                     | 355 |
|     | 19.2.11  | Timer Start Registers (TSTR)                                     | 356 |
|     | 19.2.12  | Timer Synchronous Registers (TSYR)                               | 357 |
|     | 19.2.13  | Noise Filter Control Registers (NFCR)                            | 358 |
|     | 19.2.14  | Bus Master Interface                                             | 360 |
|     | 19.3 O   | peration                                                         | 361 |
|     | 19.3.1   | Basic Functions                                                  | 361 |
|     | 19.3.2   | Synchronous Operation                                            | 367 |
|     | 19.3.3   | Buffer Operation                                                 | 369 |
|     | 19.3.4   | Cascaded Operation                                               | 373 |

|     | 19.3.5   | PWM Modes                                                                                  | 378 |
|-----|----------|--------------------------------------------------------------------------------------------|-----|
|     | 19.3.6   | Phase Counting Mode                                                                        | 382 |
|     | 19.3.7   | External Pulse Width Measurement                                                           | 388 |
|     | 19.3.8   | Noise Filter                                                                               | 389 |
|     | 19.4 Int | errupt Sources                                                                             | 390 |
|     | 19.4.1   | Interrupt Sources and Priorities                                                           | 390 |
|     | 19.4.2   | DTC Activation                                                                             | 391 |
|     | 19.4.3   | A/D Converter Activation                                                                   | 391 |
|     | 19.5 Op  | eration Timing                                                                             | 392 |
|     | 19.5.1   | Input/Output Timing                                                                        | 392 |
|     | 19.5.2   | Interrupt Signal Timing                                                                    | 396 |
|     | 19.6 Us  | age Notes                                                                                  | 399 |
|     | 19.6.1   | Module Clock Stop Mode Setting                                                             | 399 |
|     | 19.6.2   | Count Clock Restrictions                                                                   | 399 |
|     | 19.6.3   | Notes on Cycle Setting                                                                     | 399 |
|     | 19.6.4   | Contention between TCNT Write and Clear Operations                                         | 400 |
|     | 19.6.5   | Contention between TCNT Write and Increment Operations                                     | 400 |
|     | 19.6.6   | Contention between TGR Write Operation and Compare Match                                   | 401 |
|     | 19.6.7   | Contention between Buffer Register Write Operation and Compare Match                       | 401 |
|     | 19.6.8   | Contention between Buffer Register Write and TCNT Clear Operations                         | 402 |
|     | 19.6.9   | Contention between TGR Read Operation and Input Capture                                    | 402 |
|     | 19.6.10  | Contention between TGR Write Operation and Input Capture                                   | 403 |
|     | 19.6.11  | Contention between Buffer Register Write Operation and Input Capture                       | 404 |
|     | 19.6.12  | Contention between MTU2.TCNT Write Operation and Overflow/ Underflow in Cascaded Operation | 405 |
|     | 19.6.13  | Contention between Overflow/Underflow and Counter Clearing                                 | 406 |
|     | 19.6.14  | Contention between TCNT Write Operation and Overflow/Underflow                             | 406 |
|     | 19.6.15  | Interrupts during Periods in the Module Stop State                                         | 407 |
|     | 19.6.16  | Simultaneous Input Capture in MTU1.TCNT and MTU2.TCNT in Cascade Connection                | 407 |
|     | 19.6.17  | Point for Caution Regarding MTU5.TCNT and MTU5.TGR Registers                               | 407 |
|     | 19.6.18  | Continuous Output of Interrupt Signal in Response to a Compare Match                       | 408 |
|     | 19.7 MT  | ΓU Output Pin Initialization                                                               | 409 |
|     | 19.7.1   | Operating Modes                                                                            | 409 |
|     | 19.7.2   | Operation in Case of Re-Setting Due to Error during Operation                              | 409 |
|     | 19.7.3   | Overview of Pin Initialization Procedures                                                  |     |
|     |          | and Mode Transitions in Case of Error during Operation                                     | 410 |
| 20. | Compare  | Match Timer (CMT)                                                                          | 423 |
|     | 20.1 Ov  | erview                                                                                     | 423 |
|     | 20.2 Re  | gister Descriptions                                                                        | 424 |
|     | 20.2.1   | Compare Match Timer Start Register 0 (CMSTR0)                                              | 424 |
|     | 20.2.2   | Compare Match Timer Control Register (CMCR)                                                | 424 |
|     | 20.2.3   | Compare Match Counter (CMCNT)                                                              | 425 |

|    | 20.2.4   | Compare Match Constant Register (CMCOR)                                                  | 425    |
|----|----------|------------------------------------------------------------------------------------------|--------|
|    | 20.3     | Operation                                                                                | 426    |
|    | 20.3.    | Periodic Count Operation                                                                 | 426    |
|    | 20.3.2   | CMCNT Count Timing                                                                       | 426    |
|    | 20.4     | Interrupts                                                                               | 427    |
|    | 20.4.    | Interrupt Sources                                                                        | 427    |
|    | 20.4.2   | Timing of Compare Match Interrupt Generation                                             | 427    |
|    | 20.5     | Usage Notes                                                                              | 428    |
|    | 20.5.    | Setting the Module Stop Function                                                         | 428    |
|    | 20.5.2   | Conflict between CMCNT Counter Writing and Compare Match                                 | 428    |
|    | 20.5.3   | Conflict between CMCNT Counter Writing and Incrementing                                  | 428    |
| 21 | . Realti | me Clock (RTCA)                                                                          | 429    |
|    | 21.1     | Overview                                                                                 | 429    |
|    | 21.2     | Register Descriptions                                                                    | 431    |
|    | 21.2.    | 64-Hz Counter (R64CNT)                                                                   | 431    |
|    | 21.2.2   | Second Counter (RSECCNT)/Binary Counter 0 (BCNT0)                                        | 432    |
|    | 21.2.3   | Minute Counter (RMINCNT)/Binary Counter 1 (BCNT1)                                        | 433    |
|    | 21.2.4   | Hour Counter (RHRCNT)/Binary Counter 2 (BCNT2)                                           | 434    |
|    | 21.2.    | Day-of-Week Counter (RWKCNT)/Binary Counter 3 (BCNT3)                                    | 435    |
|    | 21.2.0   | Date Counter (RDAYCNT)                                                                   | 436    |
|    | 21.2.    | Month Counter (RMONCNT)                                                                  | 437    |
|    | 21.2.3   | Year Counter (RYRCNT)                                                                    | 437    |
|    | 21.2.9   | Second Alarm Register (RSECAR)/Binary Counter 0 Alarm Register (BCNT0AR)                 | 438    |
|    | 21.2.    | 0 Minute Alarm Register (RMINAR)/Binary Counter 1 Alarm Register (BCNT1AR)               | 439    |
|    | 21.2.    | 1 Hour Alarm Register (RHRAR)/Binary Counter 2 Alarm Register (BCNT2AR)                  | 440    |
|    | 21.2.    | 2 Day-of-Week Alarm Register (RWKAR)/Binary Counter 3 Alarm Register (BCNT3AR)           | 441    |
|    | 21.2.    | 3 Date Alarm Register (RDAYAR)/Binary Counter 0 Alarm Enable Register (BCNT0AEF          | ₹) 442 |
|    | 21.2.    | 4 Month Alarm Register (RMONAR)/Binary Counter 1 Alarm Enable Register (BCNT1AER)        | 443    |
|    | 21.2.    | 5 Year Alarm Register (RYRAR)/Binary Counter 2 Alarm Enable Register (BCNT2AER)          | 444    |
|    | 21.2.    | 6 Year Alarm Enable Register (RYRAREN)/Binary Counter 3 Alarm Enable Register (BCNT3AER) | 445    |
|    | 21.2.    | 7 RTC Control Register 1 (RCR1)                                                          | 446    |
|    | 21.2.    | 8 RTC Control Register 2 (RCR2)                                                          | 447    |
|    | 21.2.    | 9 RTC Control Register 3 (RCR3)                                                          | 451    |
|    | 21.2.2   | Time Error Adjustment Register (RADJ)                                                    | 452    |
|    | 21.3     | Operation                                                                                | 453    |
|    | 21.3.    | Outline of Initial Settings of Registers after Power On                                  | 453    |
|    | 21.3.2   | Clock and Count Mode Setting Procedure                                                   | 454    |
|    | 21.3.3   | Setting the Time                                                                         | 455    |
|    | 21.3.4   | 30-Second Adjustment                                                                     | 455    |
|    | 21.3.    | Reading 64-Hz Counter and Time                                                           | 456    |
|    |          |                                                                                          |        |

|    | 21.3.6      | Alarm Function                                                                     | 457 |
|----|-------------|------------------------------------------------------------------------------------|-----|
|    | 21.3.7      | Procedure for Disabling Alarm Interrupt                                            | 458 |
|    | 21.3.8      | Time Error Adjustment Function                                                     | 458 |
|    | 21.3.8.     | 1 Automatic Adjustment                                                             | 458 |
|    | 21.3.8.     | 2 Adjustment by Software                                                           | 459 |
|    | 21.3.8.     | Procedure for Changing the Mode of Adjustment                                      | 460 |
|    | 21.3.8.     | Procedure for Stopping Adjustment                                                  | 460 |
|    | 21.4 Inte   | rrupt Sources                                                                      | 461 |
|    | 21.5 Usa    | ge Notes                                                                           | 463 |
|    | 21.5.1      | Register Writing during Counting                                                   | 463 |
|    | 21.5.2      | Use of Periodic Interrupts                                                         | 463 |
|    | 21.5.3      | RTCOUT (1-Hz/64-Hz) Clock Output                                                   | 463 |
|    | 21.5.4      | Transitions to Low Power Consumption Modes after Setting Registers                 | 464 |
|    | 21.5.5      | Notes When Writing to and Reading from Registers                                   | 464 |
|    | 21.5.6      | Changing the Count Mode                                                            | 464 |
|    | 21.5.7      | Initialization Procedure When the Realtime Clock is Not to be Used                 | 465 |
| 22 | . Independe | ent Watchdog Timer (IWDTa)                                                         | 466 |
|    | 22.1 Ove    | rview                                                                              | 466 |
|    | 22.2 Reg    | ister Descriptions                                                                 | 468 |
|    | 22.2.1      | IWDT Refresh Register (IWDTRR)                                                     | 468 |
|    | 22.2.2      | IWDT Control Register (IWDTCR)                                                     | 469 |
|    | 22.2.3      | IWDT Status Register (IWDTSR)                                                      | 472 |
|    | 22.2.4      | IWDT Reset Control Register (IWDTRCR)                                              | 473 |
|    | 22.2.5      | IWDT Count Stop Control Register (IWDTCSTPR)                                       | 474 |
|    | 22.2.6      | Option Function Select Register 0 (OFS0)                                           | 474 |
|    | 22.3 Ope    | ration                                                                             | 475 |
|    | 22.3.1      | Count Operation in Each Start Mode                                                 | 475 |
|    | 22.3.1.     | 1 Register Start Mode                                                              | 475 |
|    | 22.3.1.     | 2 Auto-Start Mode                                                                  | 477 |
|    | 22.3.2      | Control over Writing to the IWDTCR, IWDTRCR, and IWDTCSTPR Registers               | 479 |
|    | 22.3.3      | Refresh Operation                                                                  | 480 |
|    | 22.3.4      | Status Flags                                                                       | 482 |
|    | 22.3.5      | Reset Output                                                                       | 482 |
|    | 22.3.6      | Interrupt Sources                                                                  | 482 |
|    | 22.3.7      | Reading the Counter Value                                                          | 483 |
|    | 22.3.8      | Correspondence between Option Function Select Register 0 (OFS0) and IWDT Registers | 484 |
|    | 22.4 Usa    | ge Notes                                                                           | 484 |
|    | 22.4.1      | Refresh Operations                                                                 | 484 |
|    | 22.4.2      | Clock Divide Ratio Setting                                                         | 484 |
|    | 22.4.3      | Note on Parallel Use of the Voltage Monitoring 1 Reset and IWDT Reset              | 484 |

| 23. | Serial ( | Communications Interface (SCIe, SCIf)            | 485 |
|-----|----------|--------------------------------------------------|-----|
|     | 23.1     | Overview                                         | 485 |
|     | 23.2     | Register Descriptions                            | 491 |
|     | 23.2.1   | Receive Shift Register (RSR)                     | 491 |
|     | 23.2.2   | Receive Data Register (RDR)                      | 491 |
|     | 23.2.3   | Transmit Data Register (TDR)                     | 491 |
|     | 23.2.4   | Transmit Shift Register (TSR)                    | 491 |
|     | 23.2.5   | Serial Mode Register (SMR)                       | 492 |
|     | 23.2.6   | Serial Control Register (SCR)                    | 496 |
|     | 23.2.7   | Serial Status Register (SSR)                     | 500 |
|     | 23.2.8   | Smart Card Mode Register (SCMR)                  | 505 |
|     | 23.2.9   | Bit Rate Register (BRR)                          | 507 |
|     | 23.2.10  | Serial Extended Mode Register (SEMR)             | 514 |
|     | 23.2.11  | Noise Filter Setting Register (SNFR)             | 516 |
|     | 23.2.12  | 2 I <sup>2</sup> C Mode Register 1 (SIMR1)       | 517 |
|     | 23.2.13  | 3 I <sup>2</sup> C Mode Register 2 (SIMR2)       | 518 |
|     | 23.2.14  | I <sup>2</sup> C Mode Register 3 (SIMR3)         | 519 |
|     | 23.2.15  | 5 I <sup>2</sup> C Status Register (SISR)        | 521 |
|     | 23.2.16  | SPI Mode Register (SPMR)                         | 522 |
|     | 23.2.17  | Extended Serial Module Enable Register (ESMER)   | 523 |
|     | 23.2.18  | Control Register 0 (CR0)                         | 524 |
|     | 23.2.19  | Control Register 1 (CR1)                         | 524 |
|     | 23.2.20  | Control Register 2 (CR2)                         | 525 |
|     | 23.2.21  | Control Register 3 (CR3)                         | 526 |
|     | 23.2.22  | Port Control Register (PCR)                      | 526 |
|     | 23.2.23  | 3 Interrupt Control Register (ICR)               | 527 |
|     | 23.2.24  | Status Register (STR)                            | 528 |
|     | 23.2.25  | Status Clear Register (STCR)                     | 529 |
|     | 23.2.26  | 6 Control Field 0 Data Register (CF0DR)          | 529 |
|     | 23.2.27  | Control Field 0 Compare Enable Register (CF0CR)  | 530 |
|     | 23.2.28  | Control Field 0 Receive Data Register (CF0RR)    | 530 |
|     | 23.2.29  | Primary Control Field 1 Data Register (PCF1DR)   | 530 |
|     | 23.2.30  | Secondary Control Field 1 Data Register (SCF1DR) | 531 |
|     | 23.2.3   | Control Field 1 Compare Enable Register (CF1CR)  | 531 |
|     | 23.2.32  | Control Field 1 Receive Data Register (CF1RR)    | 531 |
|     | 23.2.33  | Timer Control Register (TCR)                     | 532 |
|     | 23.2.34  | Timer Mode Register (TMR)                        | 532 |
|     | 23.2.35  | Timer Prescaler Register (TPRE)                  | 533 |
|     | 23.2.36  | 5 Timer Count Register (TCNT)                    | 533 |
|     | 23.3     | Operation in Asynchronous Mode                   | 534 |
|     | 23.3.1   | Serial Data Transfer Format                      | 535 |

| 23.3.2   | Receive Data Sampling Timing and Reception Margin in Asynchronous Mode       | 536 |
|----------|------------------------------------------------------------------------------|-----|
| 23.3.3   | Clock                                                                        | 537 |
| 23.3.4   | CTS and RTS Functions                                                        | 537 |
| 23.3.5   | SCI Initialization (Asynchronous Mode)                                       | 538 |
| 23.3.6   | Serial Data Transmission (Asynchronous Mode)                                 | 539 |
| 23.3.7   | Serial Data Reception (Asynchronous Mode)                                    | 542 |
| 23.4 Mu  | Iti-Processor Communications Function                                        | 546 |
| 23.4.1   | Multi-Processor Serial Data Transmission                                     | 547 |
| 23.4.2   | Multi-Processor Serial Data Reception                                        | 548 |
| 23.5 Ope | eration in Clock Synchronous Mode                                            | 551 |
| 23.5.1   | Clock                                                                        | 551 |
| 23.5.2   | CTS and RTS Functions                                                        | 552 |
| 23.5.3   | SCI Initialization (Clock Synchronous Mode)                                  | 553 |
| 23.5.4   | Serial Data Transmission (Clock Synchronous Mode)                            | 554 |
| 23.5.5   | Serial Data Reception (Clock Synchronous Mode)                               | 558 |
| 23.5.6   | Simultaneous Serial Data Transmission and Reception (Clock Synchronous Mode) | 561 |
| 23.6 Ope | eration in Smart Card Interface Mode                                         | 562 |
| 23.6.1   | Sample Connection                                                            | 562 |
| 23.6.2   | Data Format (Except in Block Transfer Mode)                                  | 563 |
| 23.6.3   | Block Transfer Mode                                                          | 564 |
| 23.6.4   | Receive Data Sampling Timing and Reception Margin                            | 565 |
| 23.6.5   | SCI Initialization (Smart Card Interface Mode)                               | 566 |
| 23.6.6   | Serial Data Transmission (Except in Block Transfer Mode)                     | 567 |
| 23.6.7   | Serial Data Reception (Except in Block Transfer Mode)                        | 570 |
| 23.6.8   | Clock Output Control                                                         | 572 |
| 23.7 Ope | eration in Simple I <sup>2</sup> C Mode                                      | 573 |
| 23.7.1   | Generation of Start, Restart, and Stop Conditions                            | 574 |
| 23.7.2   | Clock Synchronization                                                        | 576 |
| 23.7.3   | SSDA Output Delay                                                            | 577 |
| 23.7.4   | SCI Initialization (Simple I <sup>2</sup> C Mode)                            | 578 |
| 23.7.5   | Operation in Master Transmission (Simple I <sup>2</sup> C Mode)              | 579 |
| 23.7.6   | Master Reception (Simple I <sup>2</sup> C Mode)                              |     |
| 23.8 Ope | eration in Simple SPI Mode                                                   | 583 |
| 23.8.1   | States of Pins in Master and Slave Modes                                     | 584 |
| 23.8.2   | SS Function in Master Mode                                                   | 584 |
| 23.8.3   | SS Function in Slave Mode                                                    | 584 |
| 23.8.4   | Relationship between Clock and Transmit/Receive Data                         | 585 |
| 23.8.5   | SCI Initialization (Simple SPI Mode)                                         |     |
| 23.8.6   | Transmission and Reception of Serial Data (Simple SPI Mode)                  |     |
| 23.9 Ext | ended Serial Mode Control Section: Description of Operation                  |     |
| 23.9.1   | Serial Transfer Protocol                                                     | 587 |

| 23.9.2                      | Transmitting a Start Frame                                                                  | 588 |
|-----------------------------|---------------------------------------------------------------------------------------------|-----|
| 23.9.3                      | Receiving a Start Frame                                                                     | 591 |
| 23.9.3                      | .1 Priority Interrupt Bit                                                                   | 596 |
| 23.9.4                      | Detection of Bus Collisions                                                                 | 597 |
| 23.9.5                      | Digital Filter for Input on the RXDX12 Pin                                                  | 598 |
| 23.9.6                      | Bit Rate Measurement                                                                        | 599 |
| 23.9.7                      | Selectable Timing for Sampling Data Received through RXDX12                                 | 600 |
| 23.9.8                      | Timer                                                                                       | 601 |
| 23.10 Noi                   | se Cancellation Function                                                                    | 603 |
| 23.11 Inte                  | errupt Sources                                                                              | 604 |
| 23.11.1                     | Buffer Operations for TXI and RXI Interrupts                                                | 604 |
| 23.11.2                     | Interrupts in Asynchronous Mode, Clock Synchronous Mode, and Simple SPI Mode                | 604 |
| 23.11.3                     | Interrupts in Smart Card Interface Mode                                                     | 605 |
| 23.11.4                     | Interrupts in Simple I <sup>2</sup> C Mode                                                  | 606 |
| 23.11.5                     | Interrupt Requests from the Extended Serial Mode Control Section                            | 607 |
| 23.12 Usa                   | ige Notes                                                                                   | 608 |
| 23.12.1                     | Setting the Module Stop Function                                                            | 608 |
| 23.12.2                     | Break Detection and Processing                                                              | 608 |
| 23.12.3                     | Mark State and Generating Breaks                                                            | 608 |
| 23.12.4                     | Receive Error Flags and Transmit Operations (Clock Synchronous Mode and Simple SPI Mode)    | 608 |
| 23.12.5                     | Writing Data to the TDR Register                                                            | 608 |
| 23.12.6                     | Restrictions on Clock Synchronous Transmission (Clock Synchronous Mode and Simple SPI Mode) | 609 |
| 23.12.7                     | Restrictions on Using DTC                                                                   | 610 |
| 23.12.8                     | Notes on Starting Transfer                                                                  | 610 |
| 23.12.9                     | SCI Operations during Low Power Consumption State                                           | 610 |
| 23.12.10                    | External Clock Input in Clock Synchronous Mode and Simple SPI Mode                          | 613 |
| 23.12.11                    | Limitations on Simple SPI Mode                                                              | 614 |
| 23.12.12                    | Limitation 1 on Usage of the Extended Serial Mode Control Section                           | 614 |
| 23.12.13                    | Limitation 2 on Usage of the Extended Serial Mode Control Section                           | 615 |
| 23.12.14                    | Note on Transmit Enable Bit (TE Bit)                                                        | 615 |
| 23.12.15                    | Note on Stopping Reception When the RTS Function is in Use                                  | 616 |
| 24. I <sup>2</sup> C-bus Ir | nterface (RIIC)                                                                             | 617 |
| 24.1 Ove                    | erview                                                                                      | 617 |
| 24.2 Reg                    | gister Descriptions                                                                         | 620 |
| 24.2.1                      | I <sup>2</sup> C-bus Control Register 1 (ICCR1)                                             | 620 |
| 24.2.2                      | I <sup>2</sup> C-bus Control Register 2 (ICCR2)                                             | 622 |
| 24.2.3                      | I <sup>2</sup> C-bus Mode Register 1 (ICMR1)                                                | 626 |
| 24.2.4                      | I <sup>2</sup> C-bus Mode Register 2 (ICMR2)                                                | 627 |
| 24.2.5                      | I <sup>2</sup> C-bus Mode Register 3 (ICMR3)                                                | 629 |
| 24.2.6                      | I <sup>2</sup> C-bus Function Enable Register (ICFER)                                       | 631 |

| 24.2  | 2.7  | I <sup>2</sup> C-bus Status Enable Register (ICSER)                        | 633 |
|-------|------|----------------------------------------------------------------------------|-----|
| 24.2  | 2.8  | I <sup>2</sup> C-bus Interrupt Enable Register (ICIER)                     | 635 |
| 24.2  | 2.9  | I <sup>2</sup> C-bus Status Register 1 (ICSR1)                             | 637 |
| 24.2  | 2.10 | I <sup>2</sup> C-bus Status Register 2 (ICSR2)                             | 640 |
| 24.2  | 2.11 | Slave Address Register Ly (SARLy) (y = 0 to 2)                             | 643 |
| 24.2  | 2.12 | Slave Address Register Uy (SARUy) (y = 0 to 2)                             | 644 |
| 24.2  | 2.13 | I <sup>2</sup> C-bus Bit Rate Low-Level Register (ICBRL)                   | 645 |
| 24.2  | 2.14 | I <sup>2</sup> C-bus Bit Rate High-Level Register (ICBRH)                  | 646 |
| 24.2  | 2.15 | I <sup>2</sup> C-bus Transmit Data Register (ICDRT)                        | 648 |
| 24.2  | 2.16 | I <sup>2</sup> C-bus Receive Data Register (ICDRR)                         | 648 |
| 24.2  | 2.17 | I <sup>2</sup> C-bus Shift Register (ICDRS)                                | 648 |
| 24.2  | 2.18 | Timeout Internal Counter (TMOCNTL/TMOCNTU)                                 | 649 |
| 24.3  | Ope  | ration                                                                     | 650 |
| 24.3  | 3.1  | Communication Data Format                                                  | 650 |
| 24.3  | 3.2  | Initial Settings                                                           | 651 |
| 24.3  | 3.3  | Master Transmit Operation                                                  | 652 |
| 24.3  | 3.4  | Master Receive Operation                                                   | 655 |
| 24.3  | 3.5  | Slave Transmit Operation                                                   | 661 |
| 24.3  | 3.6  | Slave Receive Operation                                                    | 664 |
| 24.4  | SCL  | Synchronization Circuit                                                    | 667 |
| 24.5  | SDA  | Output Delay Function                                                      | 668 |
| 24.6  | Digi | tal Noise Filter Circuit                                                   | 669 |
| 24.7  | Add  | ress Match Detection                                                       | 670 |
| 24.7  | 7.1  | Slave-Address Match Detection                                              | 670 |
| 24.7  | 7.2  | Detection of the General Call Address                                      | 672 |
| 24.7  | 7.3  | Device-ID Address Detection                                                | 673 |
| 24.7  | 7.4  | Host Address Detection                                                     | 675 |
| 24.8  | Auto | omatic Low-Hold Function for SCL                                           | 676 |
| 24.8  | 8.1  | Function to Prevent Wrong Transmission of Transmit Data                    | 676 |
| 24.8  | 8.2  | NACK Reception Transfer Suspension Function                                | 677 |
| 24.8  | 8.3  | Function to Prevent Failure to Receive Data                                | 677 |
| 24.9  | Arb  | tration-Lost Detection Functions                                           | 679 |
| 24.9  | 9.1  | Master Arbitration-Lost Detection (MALE Bit)                               | 679 |
| 24.9  | 9.2  | Function to Detect Loss of Arbitration during NACK Transmission (NALE Bit) | 681 |
| 24.9  | 9.3  | Slave Arbitration-Lost Detection (SALE Bit)                                | 682 |
| 24.10 | Star | t Condition/Restart Condition/Stop Condition Issuing Function              | 683 |
| 24.1  | 10.1 | Issuing a Start Condition                                                  | 683 |
| 24.1  | 10.2 | Issuing a Restart Condition                                                | 683 |
| 24.1  | 10.3 | Issuing a Stop Condition                                                   | 684 |
| 24.11 | Bus  | Hanging                                                                    | 685 |
| 24.1  | 11.1 | Timeout Function                                                           | 685 |

|     | 24.11.2     | Extra SCL Clock Cycle Output Function                                                                     | 687 |
|-----|-------------|-----------------------------------------------------------------------------------------------------------|-----|
|     | 24.11.3     | RIIC Reset and Internal Reset                                                                             | 688 |
|     | 24.12 SMI   | Bus Operation                                                                                             | 689 |
|     | 24.12.1     | SMBus Timeout Measurement                                                                                 | 689 |
|     | 24.12.2     | Packet Error Code (PEC)                                                                                   | 690 |
|     | 24.12.3     | SMBus Host Notification Protocol (Notify ARP Master Command)                                              | 690 |
|     | 24.13 Inter | rrupt Sources                                                                                             | 691 |
|     | 24.13.1     | Buffer Operation for TXI and RXI Interrupts                                                               | 691 |
|     | 24.14 Rese  | ets and Register and Function States When Issuing Each Condition                                          | 692 |
|     | 24.15 Usaş  | ge Notes                                                                                                  | 693 |
|     | 24.15.1     | Setting Module Stop Function                                                                              | 693 |
|     | 24.15.2     | Notes on Starting Transfer                                                                                | 693 |
| 25. | Serial Peri | pheral Interface (RSPI)                                                                                   | 694 |
|     | 25.1 Ove    | rview                                                                                                     | 694 |
|     | 25.2 Reg    | ister Descriptions                                                                                        | 698 |
|     | 25.2.1      | RSPI Control Register (SPCR)                                                                              | 698 |
|     | 25.2.2      | RSPI Slave Select Polarity Register (SSLP)                                                                | 700 |
|     | 25.2.3      | RSPI Pin Control Register (SPPCR)                                                                         | 701 |
|     | 25.2.4      | RSPI Status Register (SPSR)                                                                               | 702 |
|     | 25.2.5      | RSPI Data Register (SPDR)                                                                                 | 704 |
|     | 25.2.6      | RSPI Sequence Control Register (SPSCR)                                                                    | 707 |
|     | 25.2.7      | RSPI Sequence Status Register (SPSSR)                                                                     | 708 |
|     | 25.2.8      | RSPI Bit Rate Register (SPBR)                                                                             | 709 |
|     | 25.2.9      | RSPI Data Control Register (SPDCR)                                                                        | 710 |
|     | 25.2.10     | RSPI Clock Delay Register (SPCKD)                                                                         | 712 |
|     | 25.2.11     | RSPI Slave Select Negation Delay Register (SSLND)                                                         | 713 |
|     | 25.2.12     | RSPI Next-Access Delay Register (SPND)                                                                    | 714 |
|     | 25.2.13     | RSPI Control Register 2 (SPCR2)                                                                           | 715 |
|     | 25.2.14     | RSPI Command Registers 0 to 7 (SPCMD0 to SPCMD7)                                                          | 716 |
|     | 25.3 Ope    | ration                                                                                                    | 719 |
|     | 25.3.1      | Overview of RSPI Operations                                                                               | 719 |
|     | 25.3.2      | Controlling RSPI Pins                                                                                     | 720 |
|     | 25.3.3      | RSPI System Configuration Examples                                                                        | 721 |
|     | 25.3.3.     | Single Master/Single Slave (with This MCU Acting as Master)                                               | 721 |
|     | 25.3.3.     | 2 Single Master/Single Slave (with This MCU Acting as Slave)                                              | 722 |
|     | 25.3.3.     | 3 Single Master/Multi-Slave (with This MCU Acting as Master)                                              | 723 |
|     | 25.3.3.     | 4 Single Master/Multi-Slave (with This MCU Acting as Slave)                                               | 724 |
|     | 25.3.3.     | Multi-Master/Multi-Slave (with This MCU Acting as Master)                                                 | 725 |
|     | 25.3.3.     | Master (Clock Synchronous Operation)/Slave (Clock Synchronous Operation) (with This MCU Acting as Master) | 726 |
|     | 25.3.3.     | Master (Clock Synchronous Operation)/Slave (Clock Synchronous Operation) (with This MCU Acting as Slave)  | 726 |
|     |             |                                                                                                           |     |

|     | 25.3.4   | Data Format                                                   | 727 |
|-----|----------|---------------------------------------------------------------|-----|
|     | 25.3.4.  | 1 When Parity is Disabled (SPCR2.SPPE = 0)                    | 728 |
|     | 25.3.4.  | When Parity is Enabled (SPCR2.SPPE = 1)                       | 732 |
|     | 25.3.5   | Transfer Format                                               | 736 |
|     | 25.3.5.  | 1 CPHA = 0                                                    | 736 |
|     | 25.3.5.  | 2 CPHA = 1                                                    | 737 |
|     | 25.3.6   | Communications Operating Mode                                 | 738 |
|     | 25.3.6.  | Full-Duplex Synchronous Serial Communications (SPCR.TXMD = 0) | 738 |
|     | 25.3.6.  | 2 Transmit Operations Only (SPCR.TXMD = 1)                    | 739 |
|     | 25.3.7   | Transmit Buffer Empty/Receive Buffer Full Interrupts          | 740 |
|     | 25.3.8   | Error Detection                                               | 742 |
|     | 25.3.8.  | 1 Overrun Error                                               | 743 |
|     | 25.3.8.  | Parity Error                                                  | 744 |
|     | 25.3.8.  | 3 Mode Fault Error                                            | 745 |
|     | 25.3.9   | Initializing RSPI                                             | 746 |
|     | 25.3.9.  | 1 Initialization by Clearing the SPE Bit                      | 746 |
|     | 25.3.9.  | 2 System Reset                                                | 746 |
|     | 25.3.10  | SPI Operation                                                 | 747 |
|     | 25.3.10  | 0.1 Master Mode Operation                                     | 747 |
|     | 25.3.10  | 0.2 Slave Mode Operation                                      | 757 |
|     | 25.3.11  | Clock Synchronous Operation                                   | 761 |
|     | 25.3.11  | .1 Master Mode Operation                                      | 761 |
|     | 25.3.11  | 1.2 Slave Mode Operation                                      | 765 |
|     | 25.3.12  | Loopback Mode                                                 | 767 |
|     | 25.3.13  | Self-Diagnosis of Parity Bit Function                         | 768 |
|     | 25.3.14  | Interrupt Sources                                             | 769 |
|     | 25.4 Usa | ge Notes                                                      | 770 |
|     | 25.4.1   | Setting Module Stop Function                                  | 770 |
|     | 25.4.2   | Note on Low Power Consumption Functions                       | 770 |
|     | 25.4.3   | Notes on Starting Transfer                                    | 770 |
|     | 25.4.4   | Notes on the SPRF and SPTEF flags                             | 770 |
| 26. | CRC Calc | ulator (CRC)                                                  | 771 |
|     | 26.1 Ove | rview                                                         | 771 |
|     | 26.2 Reg | ister Descriptions                                            | 772 |
|     | 26.2.1   | CRC Control Register (CRCCR)                                  | 772 |
|     | 26.2.2   | CRC Data Input Register (CRCDIR)                              | 772 |
|     | 26.2.3   | CRC Data Output Register (CRCDOR)                             | 773 |
|     | 26.3 Ope | ration                                                        | 774 |
|     | 26.4 Usa | ge Notes                                                      | 777 |
|     | 26.4.1   | Module Stop Function Setting                                  | 777 |
|     | 26.4.2   | Note on Transmission                                          | 777 |
|     |          |                                                               |     |

| 27. | 12-B             | Bit A/D  | Converter (S12ADb)                                                       | 778 |
|-----|------------------|----------|--------------------------------------------------------------------------|-----|
|     | 27.1             | Ove      | rview                                                                    | 778 |
|     | 27.2             | Regi     | ister Descriptions                                                       | 782 |
|     | 27.2             | 2.1      | A/D Data Registers y (ADDRy) (y = 0 to 4, 6, 8 to 15)                    | 782 |
|     | 27.2             | 2.2      | A/D Data Duplication Register (ADDBLDR)                                  | 784 |
|     | 27.2             | 2.3      | A/D Temperature Sensor Data Register (ADTSDR)                            | 785 |
|     | 27.2.4           |          | A/D Internal Reference Voltage Data Register (ADOCDR)                    | 786 |
|     | 27.2.5<br>27.2.6 |          | A/D Control Register (ADCSR)                                             | 787 |
|     |                  |          | A/D Channel Select Register A (ADANSA)                                   | 790 |
|     | 27.2             | 2.7      | A/D Channel Select Register B (ADANSB)                                   | 791 |
|     | 27.2             | 2.8      | A/D-Converted Value Addition Mode Select Register (ADADS)                | 792 |
|     | 27.2             | 2.9      | A/D-Converted Value Addition Count Select Register (ADADC)               | 793 |
|     | 27.2             | 2.10     | A/D Control Extended Register (ADCER)                                    | 794 |
|     | 27.2             | 2.11     | A/D Start Trigger Select Register (ADSTRGR)                              | 795 |
|     | 27.2             | 2.12     | A/D Converted Extended Input Control Register (ADEXICR)                  | 797 |
|     | 27.2             | 2.13     | A/D Sampling State Register n (ADSSTRn) (n = 0 to 4, 6, L, T, O)         | 798 |
|     | 27.3             | Oper     | ration                                                                   | 799 |
|     | 27.3             | 8.1      | Scanning Operation                                                       | 799 |
|     | 27.3             | 3.2      | Single Scan Mode                                                         | 800 |
|     | 2                | 27.3.2.1 | 1 Basic Operation                                                        | 800 |
|     | 2                | 27.3.2.2 | 2 A/D Conversion When Temperature Sensor Output is Selected              | 801 |
|     | 27.3.2.          |          | A/D Conversion When Internal Reference Voltage is Selected               | 802 |
|     | 2                | 27.3.2.4 | 4 A/D Conversion in Double Trigger Mode                                  | 803 |
|     | 27.3             | 3.3      | Continuous Scan Mode                                                     | 804 |
|     | 2                | 27.3.3.1 | 1 Basic Operation                                                        | 804 |
|     | 27.3             | 3.4      | Group Scan Mode                                                          | 805 |
|     | 2                | 27.3.4.1 | 1 Basic Operation                                                        | 805 |
|     | 2                | 27.3.4.2 | 2 A/D Conversion in Double Trigger Mode                                  | 806 |
|     | 2                | 27.3.4.3 | Notes on Using Software Trigger                                          | 807 |
|     | 27.3             | 3.5      | Analog Input Sampling and Scan Conversion Time                           | 808 |
|     | 27.3.6<br>27.3.7 |          | Usage Example of Automatic Register Clearing Function                    | 809 |
|     |                  |          | A/D-Converted Value Addition Function                                    | 809 |
|     | 27.3             | 3.8      | Starting A/D Conversion with an Asynchronous Trigger                     | 810 |
|     | 27.3             | 3.9      | Starting A/D Conversion with Synchronous Trigger from Peripheral Modules | 810 |
|     | 27.4             | Inter    | Tupt Sources                                                             | 810 |
|     | 27.4             | .1       | Interrupt Request on Completion of Each Scanning Conversion              | 810 |
|     | 27.5             | A/D      | Conversion Accuracy Definitions                                          | 811 |
|     | 27.6             | Usag     | ge Notes                                                                 | 812 |
|     | 27.6             | 5.1      | Notes on Reading Data Registers                                          | 812 |
|     | 27.6.2           |          | Notes on Stopping A/D Conversion                                         | 812 |
|     | 27.6             | 5 3      | A/D Conversion Restarting Timing and Termination Timing                  |     |

|     | 27.6.4 | Notes on Scan End Interrupt Handling                          | 812 |
|-----|--------|---------------------------------------------------------------|-----|
|     | 27.6.5 | Module Stop Function Setting                                  | 812 |
|     | 27.6.6 | Notes on Entering Low Power Consumption States                | 812 |
|     | 27.6.7 | Notes on Releasing Software Standby Mode                      | 812 |
|     | 27.6.8 | Allowable Impedance of Signal Source                          | 813 |
|     | 27.6.9 | Influence on Absolute Accuracy                                | 815 |
|     | 27.6.1 | 0 Voltage Range of Analog Power Supply Pins                   | 815 |
|     | 27.6.1 | 1 Notes on Board Design                                       | 815 |
|     | 27.6.1 | 2 Notes on Noise Prevention                                   | 816 |
|     | 27.6.1 | 3 Port Setting When 12-Bit A/D Converter Inputs are Used      | 816 |
|     | 27.6.1 | 4 Sequence of Powering on AVCC0 and VCC                       | 816 |
| 28. | Temp   | erature Sensor (TEMPSA)                                       | 817 |
|     | 28.1   | Overview                                                      | 817 |
|     | 28.2   | Register Descriptions                                         | 818 |
|     | 28.2.1 | Temperature Sensor Calibration Data Register (TSCDRH, TSCDRL) | 818 |
|     | 28.3   | Using the Temperature Sensor                                  | 819 |
|     | 28.3.1 | Before Using the Temperature Sensor                           | 819 |
|     | 28.3.2 | Setting the 12-Bit A/D Converter                              | 821 |
|     | 28.3.3 | A/D Conversion Result of Temperature Sensor Output            | 821 |
| 29. | Data ( | Operation Circuit (DOC)                                       | 822 |
|     | 29.1   | Overview                                                      | 822 |
|     | 29.2   | Register Descriptions                                         | 823 |
|     | 29.2.1 | DOC Control Register (DOCR)                                   | 823 |
|     | 29.2.2 | DOC Data Input Register (DODIR)                               | 824 |
|     | 29.2.3 | DOC Data Setting Register (DODSR)                             | 824 |
|     | 29.3   | Operation                                                     | 825 |
|     | 29.3.1 | Data Comparison Mode                                          | 825 |
|     | 29.3.2 | Data Addition Mode                                            | 826 |
|     | 29.3.3 | Data Subtraction Mode                                         | 827 |
|     | 29.4   | Interrupt Requests                                            | 827 |
|     | 29.5   | Usage Note                                                    | 827 |
|     | 29.5.1 | Module Stop Function Setting                                  | 827 |
| 30. | RAM    |                                                               | 828 |
|     | 30.1   | Overview                                                      | 828 |
|     | 30.2   | Operation                                                     | 828 |
|     | 30.2.1 | Low Power Consumption Function                                | 828 |
| 31. | Flash  | Memory                                                        | 829 |
|     | 31.1   | Overview                                                      | 829 |
|     | 31.2   | ROM Area and Block Configuration                              | 830 |
|     | 31.3   | Register Descriptions                                         | 832 |
|     | 31.3.1 | Flash P/E Mode Entry Register (FENTRYR)                       | 832 |

|      | 31.3.2   | Protection Unlock Register (FPR)                                    | 833 |
|------|----------|---------------------------------------------------------------------|-----|
|      | 31.3.3   | Protection Unlock Status Register (FPSR)                            | 833 |
|      | 31.3.4   | Flash P/E Mode Control Register (FPMCR)                             | 834 |
|      | 31.3.5   | Flash Initial Setting Register (FISR)                               | 835 |
|      | 31.3.6   | Flash Reset Register (FRESETR)                                      | 837 |
|      | 31.3.7   | Flash Area Select Register (FASR)                                   | 837 |
|      | 31.3.8   | Flash Control Register (FCR)                                        | 838 |
|      | 31.3.9   | Flash Extra Area Control Register (FEXCR)                           | 839 |
|      | 31.3.10  | Flash Processing Start Address Register H (FSARH)                   | 841 |
|      | 31.3.11  | Flash Processing Start Address Register L (FSARL)                   | 841 |
|      | 31.3.12  | Flash Processing End Address Register H (FEARH)                     | 842 |
|      | 31.3.13  | Flash Processing End Address Register L (FEARL)                     | 842 |
|      | 31.3.14  | Flash Read Buffer Register H (FRBH)                                 | 842 |
|      | 31.3.15  | Flash Read Buffer Register L (FRBL)                                 | 843 |
|      | 31.3.16  | Flash Write Buffer Register H (FWBH)                                | 843 |
|      | 31.3.17  | Flash Write Buffer Register L (FWBL)                                | 843 |
|      | 31.3.18  | Flash Status Register 0 (FSTATR0)                                   | 844 |
|      | 31.3.19  | Flash Status Register 1 (FSTATR1)                                   | 846 |
|      | 31.3.20  | Flash Error Address Monitor Register H (FEAMH)                      | 847 |
|      | 31.3.21  | Flash Error Address Monitor Register L (FEAML)                      | 847 |
|      | 31.3.22  | Flash Start-Up Setting Monitor Register (FSCMR)                     | 848 |
|      | 31.3.23  | Flash Access Window Start Address Monitor Register (FAWSMR)         | 848 |
|      | 31.3.24  | Flash Access Window End Address Monitor Register (FAWEMR)           | 849 |
|      | 31.3.25  | Unique ID Register n (UIDRn) (n = 0 to 31)                          | 849 |
| 31.4 | 4 Start  | -Up Program Protection                                              | 850 |
| 31.  | 5 Area   | Protection                                                          | 851 |
| 31.  | 6 Prog   | ramming and Erasure                                                 | 852 |
|      | 31.6.1   | Sequencer Modes                                                     | 852 |
|      | 31.6.1.1 | Read Mode                                                           | 852 |
|      | 31.6.1.2 | P/E Mode                                                            | 852 |
|      | 31.6.2   | Mode Transitions                                                    | 853 |
|      | 31.6.2.1 | Transition from Read Mode to P/E Mode                               | 853 |
|      | 31.6.2.2 | 2 Transition from P/E Mode to Read Mode                             | 854 |
|      | 31.6.3   | Software Commands                                                   | 855 |
|      | 31.6.4   | Software Command Usage                                              | 856 |
|      | 31.6.4.1 | Program                                                             | 856 |
|      | 31.6.4.2 | Block Erase                                                         | 857 |
|      | 31.6.4.3 | Blank Check                                                         | 858 |
|      | 31.6.4.4 | Start-Up Area Information Program/Access Window Information Program | 859 |
|      | 31.6.4.5 | Unique ID Read                                                      | 860 |
|      | 31.6.4.6 | Forced Stop of Software Commands                                    | 861 |

|     | 31.6.5   | Interrupt                                          | 861 |
|-----|----------|----------------------------------------------------|-----|
| 31. | .7 Boot  | Mode                                               | 862 |
|     | 31.7.1   | Boot Mode (SCI)                                    | 862 |
|     | 31.7.1.1 | System Configuration in Boot Mode (SCI)            | 862 |
|     | 31.7.1.2 | Starting Up in Boot Mode (SCI)                     | 865 |
|     | 31.7.2   | Boot Mode (FINE Interface)                         | 866 |
|     | 31.7.2.1 | Operating Conditions in Boot Mode (FINE Interface) | 866 |
| 31. | .8 Flash | Memory Access Disable Function                     | 867 |
|     | 31.8.1   | ID Code Protection                                 | 867 |
|     | 31.8.1.1 | Boot Mode ID Code Protection                       | 868 |
|     | 31.8.1.2 | On-Chip Debugging Emulator ID Code Protection      | 870 |
| 31. | .9 Com   | munication Protocol                                | 871 |
|     | 31.9.1   | State Transition in Boot Mode (SCI)                | 871 |
|     | 31.9.2   | Command and Response Configuration                 | 872 |
|     | 31.9.3   | Boot Mode Status Inquiry                           | 873 |
|     | 31.9.4   | Inquiry Commands                                   | 874 |
|     | 31.9.4.1 | Supported Device Inquiry                           | 874 |
|     | 31.9.4.2 | Data Area Availability Inquiry                     | 874 |
|     | 31.9.4.3 | User Area Information Inquiry                      | 875 |
|     | 31.9.4.4 | Block Information Inquiry                          | 875 |
|     | 31.9.5   | Setting Commands                                   | 876 |
|     | 31.9.5.1 | Device Select                                      | 876 |
|     | 31.9.5.2 | Operating Frequency Select                         | 877 |
|     | 31.9.5.3 | Program/Erase State Transition                     | 878 |
|     | 31.9.6   | ID Code Authentication Command                     | 879 |
|     | 31.9.6.1 | ID Code Check                                      | 879 |
|     | 31.9.6.2 | Erase Ready                                        | 880 |
|     | 31.9.7   | Program/Erase Commands                             | 880 |
|     | 31.9.7.1 | User Area Program Preparation                      | 881 |
|     | 31.9.7.2 | Program                                            | 881 |
|     | 31.9.7.3 | Erase Preparation                                  | 882 |
|     | 31.9.7.4 | Block Erase                                        | 882 |
|     | 31.9.8   | Read-Check Commands                                | 883 |
|     | 31.9.8.1 | Memory Read                                        | 883 |
|     | 31.9.8.2 | User Area Checksum                                 | 884 |
|     | 31.9.8.3 | User Area Blank Check                              | 884 |
|     | 31.9.8.4 | Access Window Information Program                  | 885 |
|     | 31.9.8.5 | Access Window Read                                 | 886 |
|     | 31.9.9   | Serial Programmer Operation in Boot Mode (SCI)     | 887 |
|     | 31.9.9.1 | Bit Rate Automatic Adjustment Procedure            | 888 |
|     | 31.9.9.2 | Procedure to Receive the MCU Information           | 889 |

|    | 3        | 1.9.9.3      | Procedure to Select the Device and Change the Bit Rate      | 890 |
|----|----------|--------------|-------------------------------------------------------------|-----|
|    | 3        | 1.9.9.4      | Transition to the Program/Erase State                       | 891 |
|    | 3        | 1.9.9.5      | Unlock Boot Mode ID Code Protection                         | 892 |
|    | 3        | 1.9.9.6      | Erase Ready Operation                                       | 893 |
|    | 3        | 1.9.9.7      | Erase the User Area                                         | 894 |
|    | 3        | 1.9.9.8      | Program the User Area                                       | 895 |
|    | 3        | 1.9.9.9      | Check Data in the User Area                                 | 896 |
|    | 3        | 1.9.9.10     | Set the Access Window in the User Area                      | 897 |
|    | 31.10    | Rewriting    | by Self-Programming                                         | 898 |
|    | 31.10    | 0.1 Ove      | rview                                                       | 898 |
|    | 31.11    | Usage No     | tes                                                         | 899 |
|    | 31.12    | Usage No     | tes in Boot Mode                                            | 900 |
| 32 | . Elect  | rical Chara  | acteristics                                                 | 901 |
|    | 32.1     | Absolute 1   | Maximum Ratings                                             | 901 |
|    | 32.2     | DC Chara     | cteristics                                                  | 902 |
|    | 32.2     | .1 Stan      | dard I/O Pin Output Characteristics (1)                     | 913 |
|    | 32.2     | .2 Stan      | dard I/O Pin Output Characteristics (2)                     | 915 |
|    | 32.2     | .3 Stan      | dard I/O Pin Output Characteristics (3)                     | 917 |
|    | 32.3     | AC Chara     | cteristics                                                  | 919 |
|    | 32.3     | .1 Cloc      | ck Timing                                                   | 919 |
|    | 32.3     | .2 Rese      | et Timing                                                   | 923 |
|    | 32.3     | .3 Timi      | ing of Recovery from Low Power Consumption Modes            | 924 |
|    | 32.3     | .4 Cont      | trol Signal Timing                                          | 927 |
|    | 32.3     | .5 Timi      | ing of On-Chip Peripheral Modules                           | 928 |
|    | 32.4     | A/D Conv     | version Characteristics                                     | 939 |
|    | 32.5     | Temperatu    | ure Sensor Characteristics                                  | 944 |
|    | 32.6     | Power-On     | Reset Circuit and Voltage Detection Circuit Characteristics | 945 |
|    | 32.7     | Oscillation  | n Stop Detection Timing                                     | 948 |
|    | 32.8     | ROM (Fla     | ash Memory for Code Storage) Characteristics                | 949 |
|    | 32.9     | Usage No     | tes                                                         | 951 |
|    | 32.9     | .1 Con       | necting VCL Capacitor and Bypass Capacitors                 | 951 |
| Ар | pendix 1 | . Port State | es in Each Processing Mode                                  | 953 |
| Ар | pendix 2 | . Package    | Dimensions                                                  | 954 |
| RE | VISION   | HISTORY      |                                                             | 961 |



RX110 Group Renesas MCUs

R01UH0421EJ0120 Rev.1.20 Jul 29, 2016

32 MHz 32-bit RX MCUs, 50 DMIPS, up to 128 Kbytes of flash memory, up to 5 comms channels, 12-bit A/D, RTC

## **Features**

#### ■ 32-bit RX CPU core

- 32 MHz maximum operating frequency Capable of 50 DMIPS when operating at 32 MHz
- Accumulator handles 64-bit results (for a single instruction) from 32-bit × 32-bit operations
- Multiplication and division unit handles 32-bit × 32-bit operations (multiplication instructions take one CPU clock cycle)
- Fast interrupt
- CISC Harvard architecture with five-stage pipeline
- Variable-length instruction format, ultra-compact code
- On-chip debugging circuit

#### ■ Low power consumption functions

- Operation from a single 1.8 to 3.6 V supply
- Three low power modes
- Supply current High-speed operating mode: 0.1 mA/MHz Software standby mode: 0.35 μA
- Recovery time from software standby mode: 4.8 μs

#### ■ On-chip flash memory for code, no wait states

- Operation at 32 MHz, read cycle of 31.25 ns
- No wait states for reading at full CPU speed
- 8 to 128 Kbyte capacities
- Programmable at 1.8 V
- For instructions and operands

#### ■ On-chip SRAM, no wait states

• 8 to 16 Kbyte capacities

#### ■ Data transfer controller (DTC)

- Four transfer modes
- Transfer can be set for each interrupt source.

#### ■ Reset and power supply voltage management

- Six types including the power-on reset (POR)
- Low voltage detection (LVD) with voltage settings

#### ■ Clock functions

- External clock input frequency: Up to 20 MHz
- Main clock oscillator frequency: 1 to 20 MHz
- Sub-clock oscillator frequency: 32.768 kHz
- Low-speed on-chip oscillator: 4 MHz
- High-speed on-chip oscillator: 32 MHz±1% (-20 to 85°C)
- IWDT-dedicated on-chip oscillator: 15 kHz
- Generate a dedicated 32.768-kHz clock for the RTC
- On-chip clock frequency accuracy measurement circuit (CAC)

#### ■ Real-time clock (RTC)

- 30-second, leap year, and error adjustment functions
- Calendar count mode or binary count mode selectable
- Capable initiating exit from software standby mode



#### ■ Independent watchdog timer (WDT)

 15-kHz on-chip oscillator produces a dedicated clock signal to drive IWDT operation.

#### ■ On-chip functions for IEC 60730 compliance

 Clock frequency accuracy measurement circuit, IWDT, functions to assist in RAM testing, etc.

#### ■ Up to five channels for communication

- SCI: Asynchronous mode, clock synchronous mode, smart card interface (up to seven channels)
- I<sup>2</sup>C bus interface: Transfer at up to 400 kbps, capable of SMBus operation (one channel)
- RSPI: Up to 16 Mbps (one channel)

#### ■ Up to 6 extended-function timers

- 16-bit MTU: Input capture/output compare, phase counting mode (four channels)
- 16-bit CMT (two channels)

#### ■ 12-bit A/D converter

- Up to 14 channels
- 1.0 µs minimum conversion speed
- Double trigger (data duplication) function for motor control

#### ■ Temperature sensor

#### ■ General I/O ports

• 5-V tolerant, open drain, input pull-up

#### ■ Multi-function pin controller (MPC)

• Multiple I/O pins can be selected for peripheral functions.

#### ■ Unique ID

• 32-byte ID code for the MCU

#### **■** Operating temperature range

- -40 to +85°C
- $-40 \text{ to } +105^{\circ}\text{C}$



## 1. Overview

## 1.1 Outline of Specifications

Table 1.1 lists the specifications, and Table 1.2 gives a comparison of the functions of the products in different packages.

Table 1.1 is for products with the greatest number of functions, so the number of peripheral modules and channels will differ in accordance with the package type. For details, see Table 1.2, Comparison of Functions for Different Packages.

Table 1.1 Outline of Specifications (1/3)

| Table 1.1             | Outline of Specifications (1/3)                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|-----------------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Classification        | Module/Function                                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| CPU                   | CPU                                            | <ul> <li>Maximum operating frequency: 32 MHz</li> <li>32-bit RX CPU</li> <li>Minimum instruction execution time: One instruction per one clock cycle</li> <li>Address space: 4-Gbyte linear</li> <li>Register set</li> <li>General purpose: Sixteen 32-bit registers</li> <li>Control: Eight 32-bit registers</li> <li>Accumulator: One 64-bit register</li> <li>Basic instructions: 73</li> <li>DSP instructions: 9</li> <li>Addressing modes: 10</li> <li>Data arrangement Instructions: Little endian Data: Selectable as little endian or big endian</li> <li>On-chip 32-bit multiplier: 32-bit → 32-bit → 64-bit</li> <li>On-chip divider: 32-bit ÷ 32-bit → 32 bits</li> <li>Barrel shifter: 32 bits</li> </ul>                                                                                                                    |  |  |  |
| Memory                | ROM                                            | <ul> <li>Capacity: 8 K /16 K /32 K /64 K /96 K /128 Kbytes</li> <li>32 MHz, no-wait memory access</li> <li>Programming/erasing method:<br/>Serial programming (asynchronous serial communication), self-programming</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|                       | RAM                                            | <ul> <li>Capacity: 8 K /10 K /16 Kbytes</li> <li>32 MHz, no-wait memory access</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| MCU operating mo      | ode                                            | Single-chip mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| Clock                 | Clock generation circuit                       | <ul> <li>Main clock oscillator, sub-clock oscillator, low-speed on-chip oscillator, high-speed on-chip oscillator and IWDT-dedicated on-chip oscillator</li> <li>Oscillation stop detection: Available</li> <li>Clock frequency accuracy measurement circuit (CAC)</li> <li>Independent settings for the system clock (ICLK), peripheral module clock (PCLK), and FlashIF clock (FCLK)</li> <li>The CPU and system sections such as other bus masters run in synchronization with the system clock (ICLK): 32 MHz (at max.)</li> <li>Peripheral modules run in synchronization with the PCLK: 32 MHz (at max.)</li> <li>The flash peripheral circuit runs in synchronization with the FCLK: 32 MHz (at max.)</li> <li>The ICLK frequency can only be set to FCLK, PCLKB, or PCLKD multiplied by n (n: 1, 2, 4, 8, 16, 32 64).</li> </ul> |  |  |  |
| Resets                |                                                | RES# pin reset, power-on reset, voltage monitoring reset, independent watchdog timer reset, and software reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| Voltage detection     | Voltage detection circuit (LVDAa)              | When the voltage on VCC falls below the voltage detection level, an internal reset or internal internal is generated.     Voltage detection circuit 1 is capable of selecting the detection voltage from 10 levels     Voltage detection circuit 2 is capable of selecting the detection voltage from 4 levels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| Low power consumption | Low power consumption functions                | <ul> <li>Module stop function</li> <li>Three low power consumption modes</li> <li>Sleep mode, deep sleep mode, and software standby mode</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|                       | Function for lower operating power consumption | Operating power control modes     High-speed operating mode, middle-speed operating mode, and low-speed operating mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| Interrupt             | Interrupt controller (ICUb)                    | <ul> <li>Interrupt vectors: 65</li> <li>External interrupts: 9 (NMI, IRQ0 to IRQ7 pins)</li> <li>Non-maskable interrupts: 4 (NMI pin, voltage monitoring 1 interrupt, voltage monitoring 2 interrupt, and IWDT interrupt)</li> <li>16 levels specifiable for the order of priority</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| DMA                   | Data transfer controller (DTCa)                | <ul> <li>Transfer modes: Normal transfer, repeat transfer, and block transfer</li> <li>Activation sources: Interrupts</li> <li>Chain transfer function</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |

Table 1.1 Outline of Specifications (2/3)

| Table 1.1 Outline of Specificati |                                               | ions (2/3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|----------------------------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Classification                   | Module/Function                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| I/O ports                        | General I/O ports                             | 64-pin /48-pin /40-pin /36-pin  • I/O: 50/34/28/24  • Input: 2/2/1/1  • Pull-up resistors: 42/28/23/20  • Open-drain outputs: 38/28/23/20  • 5-V tolerance: 4/4/4/4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| Multi-function pin               | controller (MPC)                              | Capable of selecting the input/output function from multiple pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| Timers                           | Multi-function timer pulse<br>unit 2 (MTU2b)  | (16 bits × 4 channels) × 1 unit     Time bases for the four 16-bit timer channels can be provided via up to 8 pulse-input/output lines and three pulse-input lines     Select from among eight or seven counter-input clock signals for each channel (PCLK/1, PCLK/4, PCLK/16, PCLK/64, PCLK/256, PCLK/1024, MTCLKA, MTCLKB, MTCLKC, MTCLKD) other than channel 5, for which only four signals are available.     Input capture function     13 output compare/input capture registers     Pulse output mode     Phase counting mode     Generation of triggers for A/D converter conversion                                                                                                                                                                                                                |  |  |
|                                  | Compare match timer (CMT)                     | <ul> <li>(16 bits × 2 channels) × 1 unit</li> <li>Select from among four clock signals (PCLK/8, PCLK/32, PCLK/128, PCLK/512)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|                                  | Independent watchdog timer (IWDTa)            | <ul> <li>14 bits x 1 channel</li> <li>Count clock: Dedicated low-speed on-chip oscillator for the IWDT<br/>Frequency divided by 1, 16, 32, 64, 128, or 256</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|                                  | Realtime clock (RTCA)                         | <ul> <li>Clock source: Sub-clock</li> <li>Calendar count mode or binary count mode selectable</li> <li>Interrupts: Alarm interrupt, periodic interrupt, and carry interrupt</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Communication functions          | Serial communications interfaces (SCIe, SCIf) | <ul> <li>3 channels (channel 1, 5: SCle, channel 12: SClf)</li> <li>Serial communications modes: Asynchronous, clock synchronous, and smart card interface</li> <li>On-chip baud rate generator allows selection of the desired bit rate</li> <li>Choice of LSB first or MSB first transfer</li> <li>Average transfer rate clock can be input from MTU2 timers</li> <li>Simple I<sup>2</sup>C</li> <li>Simple SPI</li> <li>Master/slave mode supported (SClf only)</li> <li>Start frame and information frame are included (SClf only)</li> <li>Start-bit detection in asynchronous mode: Low level or falling edge is selectable (SCle/SClf)</li> </ul>                                                                                                                                                    |  |  |
|                                  | I <sup>2</sup> C bus interface (RIIC)         | 1 channel     Communications formats:     I <sup>2</sup> C bus format/SMBus format     Master mode or slave mode selectable     Supports fast mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                                  | Serial peripheral interface (RSPI)            | <ul> <li>1 channel</li> <li>Transfer facility</li> <li>Using the MOSI (master out, slave in), MISO (master in, slave out), SSL (slave select), and RSPI clock (RSPCK) signals enables serial transfer through SPI operation (four lines) or clock-synchronous operation (three lines)</li> <li>Capable of handling serial transfer as a master or slave</li> <li>Data formats</li> <li>Choice of LSB first or MSB first transfer The number of bits in each transfer can be changed to 8, 9, 10, 11, 12, 13, 14, 15, 16, 20, 24, or 32 bits.</li> <li>128-bit buffers for transmission and reception</li> <li>Up to four frames can be transmitted or received in a single transfer operation (with each frame having up to 32 bits)</li> <li>Double buffers for both transmission and reception</li> </ul> |  |  |
| 12-bit A/D converter (S12ADb)    |                                               | <ul> <li>1 unit (1 unit x 14 channels)</li> <li>12-bit resolution</li> <li>Minimum conversion time: 1.0 µs per channel when the ADCLK is operating at 32 MHz</li> <li>Operating modes Scan mode (single scan mode, continuous scan mode, and group scan mode) </li> <li>Double trigger mode (duplication of A/D conversion data)</li> <li>A/D conversion start conditions A software trigger, a trigger from a timer (MTU), or an external trigger signal </li> </ul>                                                                                                                                                                                                                                                                                                                                       |  |  |
| Temperature sens                 | , ,                                           | <ul> <li>1 channel</li> <li>The voltage of the temperature is converted into a digital value by the 12-bit A/D converter.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| CRC calculator (CRC)             |                                               | <ul> <li>CRC code generation for arbitrary amounts of data in 8-bit units</li> <li>Select any of three generating polynomials:         X<sup>8</sup> + X<sup>2</sup> + X + 1, X<sup>16</sup> + X<sup>15</sup> + X<sup>2</sup> + 1, or X<sup>16</sup> + X<sup>12</sup> + X<sup>5</sup> + 1</li> <li>Generation of CRC codes for use with LSB first or MSB first communications is selectable.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |

Table 1.1 Outline of Specifications (3/3)

| Classification                              | Module/Function | Description                                                                                                                                                                                                                                                                                                                                                             |  |  |
|---------------------------------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Data operation cir                          | cuit (DOC)      | Comparison, addition, and subtraction of 16-bit data                                                                                                                                                                                                                                                                                                                    |  |  |
| Unique ID                                   |                 | 32-byte ID code for the MCU                                                                                                                                                                                                                                                                                                                                             |  |  |
| Power supply voltages/Operating frequencies |                 | VCC = 1.8 to 2.4 V: 8 MHz, VCC = 2.4 to 2.7 V: 16 MHz, VCC = 2.7 to 3.6 V: 32 MHz                                                                                                                                                                                                                                                                                       |  |  |
| Supply current                              |                 | 3.2 mA at 32 MHz (typ.)                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Operating temperatures                      |                 | D version: -40 to +85°C, G version: -40 to +105°C                                                                                                                                                                                                                                                                                                                       |  |  |
| Packages                                    |                 | 64-pin LFQFP (PLQP0064KB-A) 10 × 10 mm, 0.5 mm pitch 64-pin LQFP (PLQP0064GA-A) 14 × 14 mm, 0.8 mm pitch 64-pin WFLGA (PWLG0064KA-A) 5 × 5 mm, 0.5 mm pitch 48-pin LFQFP (PLQP0048KB-A) 7 × 7 mm, 0.5 mm pitch 48-pin HWQFN (PWQN0048KB-A) 7 × 7 mm, 0.5 mm pitch 40-pin HWQFN (PWQN0040KC-A) 6 × 6 mm, 0.5 mm pitch 36-pin WFLGA (PWLG0036KA-A) 4 × 4 mm, 0.5 mm pitch |  |  |
| On-chip debuggin                            | g system        | E1 emulator (FINE interface)                                                                                                                                                                                                                                                                                                                                            |  |  |

Table 1.2 Comparison of Functions for Different Packages

|                                       |                                                                       | RX110 Group                                 |                                 |                               |                                                    |  |
|---------------------------------------|-----------------------------------------------------------------------|---------------------------------------------|---------------------------------|-------------------------------|----------------------------------------------------|--|
| Module/Functio                        | ns                                                                    | 64 Pins                                     | 48 Pins                         | 40 Pins                       | 36 Pins                                            |  |
| Interrupts External interrupts        |                                                                       | NMI, IRQ0 to IRQ7                           |                                 |                               |                                                    |  |
| DMA                                   | Data transfer controller                                              | Supported                                   |                                 |                               |                                                    |  |
| Timers                                | Multi-function timer pulse unit 2                                     |                                             | 4 channels (MTU0 to MTU2, MTU5) |                               |                                                    |  |
|                                       | Compare match timer                                                   | 2 channels x 1 unit                         |                                 |                               |                                                    |  |
|                                       | Realtime clock                                                        | Supported                                   |                                 | Not supported                 |                                                    |  |
|                                       | Independent watchdog timer                                            | Supported                                   |                                 |                               |                                                    |  |
| Communication functions               |                                                                       |                                             | 2 channels<br>(SCI1, SCI5)      |                               |                                                    |  |
|                                       | Serial communications interface [simple I <sup>2</sup> C, simple SPI] | 1 channel (SCI12)                           |                                 |                               |                                                    |  |
|                                       | I <sup>2</sup> C bus interface                                        | 1 channel                                   |                                 |                               |                                                    |  |
|                                       | Serial peripheral interface                                           | 1 channel                                   |                                 | annel<br>3 are not supported) | 1 channel<br>(SSLA1 to SSLA3<br>are not supported) |  |
| 12-bit A/D conve<br>(including high-p | rter<br>orecision channels)                                           | 14 channels<br>(6 channels)                 | 10 channels<br>(4 channels)     | 8 channels<br>(3 channels)    | 7 channels<br>(2 channels)                         |  |
| Temperature sen                       | sor                                                                   | Supported                                   |                                 |                               |                                                    |  |
| CRC calculator                        |                                                                       | Supported                                   |                                 |                               |                                                    |  |
| Packages                              |                                                                       | 64-pin LFQFP<br>64-pin LQFP<br>64-pin WFLGA | 48-pin LFQFP<br>48-pin HWQFN    | 40-pin HWQFN                  | 36-pin WFLGA                                       |  |

# 1.2 List of Products

Table 1.3 is a list of products, and Figure 1.1 shows how to read the product part no., memory capacity, and package type.

Table 1.3 List of Products (1/2)

| Group | Part No.     | Orderable Part No. | Package      | ROM<br>Capacity | RAM<br>Capacity | Maximum<br>Operating<br>Frequency | Operating<br>Temperature |
|-------|--------------|--------------------|--------------|-----------------|-----------------|-----------------------------------|--------------------------|
| RX110 | R5F51105AGFM | R5F51105AGFM#30    | PLQP0064KB-A |                 |                 |                                   |                          |
|       | R5F51105AGFK | R5F51105AGFK#30    | PLQP0064GA-A | 100 Khutoo      |                 |                                   |                          |
|       | R5F51105AGFL | R5F51105AGFL#30    | PLQP0048KB-A | - 128 Kbytes    |                 |                                   |                          |
|       | R5F51105AGNE | R5F51105AGNE#U0    | PWQN0048KB-A | •               | 16 Khyton       |                                   |                          |
|       | R5F51104AGFM | R5F51104AGFM#30    | PLQP0064KB-A |                 | - 16 Kbytes     |                                   |                          |
|       | R5F51104AGFK | R5F51104AGFK#30    | PLQP0064GA-A | 00 1/h. +       |                 |                                   |                          |
|       | R5F51104AGFL | R5F51104AGFL#30    | PLQP0048KB-A | - 96 Kbytes     |                 |                                   |                          |
|       | R5F51104AGNE | R5F51104AGNE#U0    | PWQN0048KB-A | -               |                 |                                   |                          |
|       | R5F51103AGFM | R5F51103AGFM#30    | PLQP0064KB-A |                 |                 | -                                 |                          |
|       | R5F51103AGFK | R5F51103AGFK#30    | PLQP0064GA-A | -               |                 |                                   |                          |
|       | R5F51103AGFL | R5F51103AGFL#30    | PLQP0048KB-A | 64 Kbytes       |                 |                                   |                          |
|       | R5F51103AGNE | R5F51103AGNE#U0    | PWQN0048KB-A | -               | - 10 Kbytes     | 00.1411                           | 40.4 40.500              |
|       | R5F51103AGNF | R5F51103AGNF#U0    | PWQN0040KC-A | -               |                 | 32 MHz                            | −40 to +105°C            |
|       | R5F51101AGFM | R5F51101AGFM#30    | PLQP0064KB-A |                 |                 |                                   |                          |
|       | R5F51101AGFK | R5F51101AGFK#30    | PLQP0064GA-A | -               |                 |                                   |                          |
|       | R5F51101AGFL | R5F51101AGFL#30    | PLQP0048KB-A | 32 Kbytes       |                 |                                   |                          |
|       | R5F51101AGNE | R5F51101AGNE#U0    | PWQN0048KB-A | -               |                 |                                   |                          |
|       | R5F51101AGNF | R5F51101AGNF#U0    | PWQN0040KC-A | -               |                 |                                   |                          |
|       | R5F5110JAGFM | R5F5110JAGFM#30    | PLQP0064KB-A |                 |                 | _                                 |                          |
|       | R5F5110JAGFK | R5F5110JAGFK#30    | PLQP0064GA-A | -               |                 |                                   |                          |
|       | R5F5110JAGFL | R5F5110JAGFL#30    | PLQP0048KB-A | 16 Kbytes       | 0.1/6.455       |                                   |                          |
|       | R5F5110JAGNE | R5F5110JAGNE#U0    | PWQN0048KB-A | -               | 8 Kbytes        |                                   |                          |
|       | R5F5110JAGNF | R5F5110JAGNF#U0    | PWQN0040KC-A |                 |                 |                                   |                          |
|       | R5F5110HAGNF | R5F5110HAGNF#U0    | PWQN0040KC-A | 8 Kbytes        | _               |                                   |                          |

Table 1.3 List of Products (2/2)

| Group | Part No.     | Orderable Part No. | Package      | ROM<br>Capacity | RAM<br>Capacity | Maximum<br>Operating<br>Frequency | Operating<br>Temperature |
|-------|--------------|--------------------|--------------|-----------------|-----------------|-----------------------------------|--------------------------|
| RX110 | R5F51105ADFM | R5F51105ADFM#30    | PLQP0064KB-A |                 |                 | . 1                               |                          |
|       | R5F51105ADFK | R5F51105ADFK#30    | PLQP0064GA-A | -               |                 |                                   |                          |
|       | R5F51105ADLF | R5F51105ADLF#U0    | PWLG0064KA-A | 128 Kbytes      |                 |                                   |                          |
|       | R5F51105ADFL | R5F51105ADFL#30    | PLQP0048KB-A | <u>,</u>        |                 |                                   |                          |
|       | R5F51105ADNE | R5F51105ADNE#U0    | PWQN0048KB-A | _               |                 |                                   |                          |
|       | R5F51104ADFM | R5F51104ADFM#30    | PLQP0064KB-A |                 | - 16 Kbytes     |                                   |                          |
|       | R5F51104ADFK | R5F51104ADFK#30    | PLQP0064GA-A | =               |                 |                                   |                          |
|       | R5F51104ADLF | R5F51104ADLF#U0    | PWLG0064KA-A | 96 Kbytes       |                 |                                   |                          |
|       | R5F51104ADFL | R5F51104ADFL#30    | PLQP0048KB-A | -               |                 |                                   |                          |
|       | R5F51104ADNE | R5F51104ADNE#U0    | PWQN0048KB-A | -               |                 |                                   |                          |
|       | R5F51103ADFM | R5F51103ADFM#30    | PLQP0064KB-A |                 |                 | _                                 |                          |
|       | R5F51103ADFK | R5F51103ADFK#30    | PLQP0064GA-A | -               |                 |                                   |                          |
|       | R5F51103ADLF | R5F51103ADLF#U0    | PWLG0064KA-A | 64 Kbytes       | - 10 Kbytes     |                                   |                          |
|       | R5F51103ADFL | R5F51103ADFL#30    | PLQP0048KB-A |                 |                 |                                   |                          |
|       | R5F51103ADNE | R5F51103ADNE#U0    | PWQN0048KB-A |                 |                 |                                   |                          |
|       | R5F51103ADLM | R5F51103ADLM#U0    | PWLG0036KA-A |                 |                 |                                   | −40 to +85°C             |
|       | R5F51103ADNF | R5F51103ADNF#U0    | PWQN0040KC-A | -               |                 | 32MHz                             |                          |
|       | R5F51101ADFM | R5F51101ADFM#30    | PLQP0064KB-A |                 |                 |                                   |                          |
|       | R5F51101ADFK | R5F51101ADFK#30    | PLQP0064GA-A | =               |                 |                                   |                          |
|       | R5F51101ADLF | R5F51101ADLF#U0    | PWLG0064KA-A | =               |                 |                                   |                          |
|       | R5F51101ADFL | R5F51101ADFL#30    | PLQP0048KB-A | 32 Kbytes       |                 |                                   |                          |
|       | R5F51101ADNE | R5F51101ADNE#U0    | PWQN0048KB-A | =               |                 |                                   |                          |
|       | R5F51101ADLM | R5F51101ADLM#U0    | PWLG0036KA-A | =               |                 |                                   |                          |
|       | R5F51101ADNF | R5F51101ADNF#U0    | PWQN0040KC-A | =               |                 |                                   |                          |
|       | R5F5110JADFM | R5F5110JADFM#30    | PLQP0064KB-A |                 |                 | _                                 |                          |
|       | R5F5110JADFK | R5F5110JADFK#30    | PLQP0064GA-A | -               |                 |                                   |                          |
|       | R5F5110JADLF | R5F5110JADLF#U0    | PWLG0064KA-A | -               |                 |                                   |                          |
|       | R5F5110JADFL | R5F5110JADFL#30    | PLQP0048KB-A | 16 Kbytes       |                 |                                   |                          |
|       | R5F5110JADNE | R5F5110JADNE#U0    | PWQN0048KB-A |                 | 8 Kbytes        |                                   |                          |
|       | R5F5110JADLM | R5F5110JADLM#U0    | PWLG0036KA-A | =               |                 |                                   |                          |
|       | R5F5110JADNF | R5F5110JADNF#U0    | PWQN0040KC-A | =               |                 |                                   |                          |
|       | R5F5110HADLM | R5F5110HADLM#U0    | PWLG0036KA-A | O. IZberter     | =               |                                   |                          |
|       | R5F5110HADNF | R5F5110HADNF#U0    | PWQN0040KC-A | - 8 Kbytes      |                 |                                   |                          |

Note: Orderable part numbers are current as of when this manual was published. Please make sure to refer to the relevant product page on the Renesas website for the latest part numbers.



Figure 1.1 How to Read the Product Part No., Memory Capacity, and Package Type

# 1.3 Block Diagram

Figure 1.2 shows a block diagram.



Figure 1.2 Block Diagram

# 1.4 Pin Functions

Table 1.4 lists the pin functions.

Table 1.4 Pin Functions (1/3)

| Classifications                   | Pin Name                             | I/O                 | Description                                                                                                                                                |
|-----------------------------------|--------------------------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Power supply                      | VCC                                  | Input               | Power supply pin. Connect it to the system power supply.                                                                                                   |
|                                   | VCL                                  | _                   | Connect this pin to the VSS pin via the 4.7 $\mu$ F smoothing capacitor used to stabilize the internal power supply. Place the capacitor close to the pin. |
|                                   | VSS                                  | Input               | Ground pin. Connect it to the system power supply (0 V).                                                                                                   |
| Analog power supply               | AVCC0                                | Input               | Analog voltage supply pin for the 12-bit A/D converter. Connect this pin to VCC when not using the 12-bit A/D converter.                                   |
|                                   | AVSS0                                | Input               | Analog ground pin for the 12-bit A/D converter. Connect this pin to VSS when not using the 12-bit A/D converter.                                           |
|                                   | VREFH0                               | Input               | Analog reference voltage supply pin for the 12-bit A/D converter. Connect this pin to VCC when not using the 12-bit A/D converter.                         |
|                                   | VREFL0                               | Input               | Analog reference ground pin for the 12-bit A/D converter. Connect this pin to VSS when not using the 12-bit A/D converter.                                 |
| Clock                             | XTAL                                 | Output/<br>Input *1 | Pins for connecting a crystal resonator. An external clock can be input through the XTAL pin.                                                              |
|                                   | EXTAL                                | Input               |                                                                                                                                                            |
|                                   | XCIN                                 | Input               | Input/output pins for the sub-clock oscillator. Connect a crystal resonator                                                                                |
|                                   | XCOUT                                | Output              | between XCIN and XCOUT.                                                                                                                                    |
|                                   | CLKOUT                               | Output              | Clock output pin.                                                                                                                                          |
| Operating mode control            | MD                                   | Input               | Pin for setting the operating mode. The signal levels on this pin must not be changed during operation.                                                    |
| System control                    | RES#                                 | Input               | Reset pin. This LSI enters the reset state when this signal goes low.                                                                                      |
| CAC                               | CACREF                               | Input               | Input pin for the clock frequency accuracy measurement circuit.                                                                                            |
| On-chip<br>emulator               | FINED                                | I/O                 | FINE interface pin.                                                                                                                                        |
| LVD                               | CMPA2                                | Input               | Detection target voltage pin for voltage detection 2.                                                                                                      |
| Interrupts                        | NMI                                  | Input               | Non-maskable interrupt request pin.                                                                                                                        |
|                                   | IRQ0 to IRQ7                         | Input               | Interrupt request pins.                                                                                                                                    |
| Multi-function timer pulse unit 2 | MTIOC0A, MTIOC0B<br>MTIOC0C, MTIOC0D | I/O                 | The TGRA0 to TGRD0 input capture input/output compare output/PWM output pins.                                                                              |
|                                   | MTIOC1A, MTIOC1B                     | I/O                 | The TGRA1 and TGRB1 input capture input/output compare output/PWM output pins.                                                                             |
|                                   | MTIOC2A, MTIOC2B                     | I/O                 | The TGRA2 and TGRB2 input capture input/output compare output/PWM output pins.                                                                             |
|                                   | MTIC5U, MTIC5V, MTIC5W               | Input               | The TGRU5, TGRV5, and TGRW5 input capture input/external pulse input pins.                                                                                 |
|                                   | MTCLKA, MTCLKB,<br>MTCLKC, MTCLKD    | Input               | Input pins for the external clock.                                                                                                                         |
| Realtime clock                    | RTCOUT                               | Output              | Output pin for the 1-Hz/64-Hz clock.                                                                                                                       |
| Serial                            | Asynchronous mode/clock              | synchrono           | ous mode                                                                                                                                                   |
| communications interface (SCIe)   | SCK1, SCK5                           | I/O                 | Input/output pins for the clock.                                                                                                                           |
|                                   | RXD1, RXD5                           | Input               | Input pins for receiving data.                                                                                                                             |
|                                   | TXD1, TXD5                           | Output              | Output pins for transmitting data.                                                                                                                         |
|                                   | CTS1#, CTS5#                         | Input               | Input pins for controlling the start of transmission and reception.                                                                                        |
|                                   | RTS1#, RTS5#                         | Output              | Output pins for controlling the start of transmission and reception.                                                                                       |

Table 1.4 Pin Functions (2/3)

| Classifications                 | Pin Name                                 | I/O      | Description                                                                                                                |  |  |  |
|---------------------------------|------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Serial                          | Simple I <sup>2</sup> C mode             |          |                                                                                                                            |  |  |  |
| communications interface (SCIe) | SSCL1, SSCL5                             | I/O      | Input/output pins for the I <sup>2</sup> C clock.                                                                          |  |  |  |
| interface (GGIC)                | SSDA1, SSDA5                             | I/O      | Input/output pins for the I <sup>2</sup> C data.                                                                           |  |  |  |
|                                 | Simple SPI mode                          |          |                                                                                                                            |  |  |  |
|                                 | SCK1, SCK5                               | I/O      | Input/output pins for the clock.                                                                                           |  |  |  |
|                                 | SMISO1, SMISO5                           | I/O      | Input/output pins for slave transmit data.                                                                                 |  |  |  |
|                                 | SMOSI1, SMOSI5                           | I/O      | Input/output pins for master transmit data.                                                                                |  |  |  |
|                                 | SS1#, SS5#                               | Input    | Chip-select input pins.                                                                                                    |  |  |  |
| Serial                          | Asynchronous mode/clock                  | synchron | ous mode                                                                                                                   |  |  |  |
| communications nterface (SCIf)  | SCK12                                    | I/O      | Input/output pin for the clock.                                                                                            |  |  |  |
| menace (GOII)                   | RXD12                                    | Input    | Input pin for receiving data.                                                                                              |  |  |  |
|                                 | TXD12                                    | Output   | Output pin for transmitting data.                                                                                          |  |  |  |
|                                 | CTS12#                                   | Input    | Input pin for controlling the start of transmission and reception.                                                         |  |  |  |
|                                 | RTS12#                                   | Output   | Output pin for controlling the start of transmission and reception.                                                        |  |  |  |
|                                 | Simple I <sup>2</sup> C mode             |          |                                                                                                                            |  |  |  |
|                                 | SSCL12 I/0                               |          | Input/output pin for the I <sup>2</sup> C clock.                                                                           |  |  |  |
|                                 | SSDA12 I/C                               |          | Input/output pin for the I <sup>2</sup> C data.                                                                            |  |  |  |
|                                 | Simple SPI mode                          |          |                                                                                                                            |  |  |  |
|                                 | SCK12                                    | I/O      | Input/output pin for the clock.                                                                                            |  |  |  |
|                                 | SMISO12                                  | I/O      | Input/output pin for slave transmit data.                                                                                  |  |  |  |
|                                 | SMOSI12                                  | I/O      | Input/output pin for master transmit data.                                                                                 |  |  |  |
|                                 | SS12#                                    | Input    | Chip-select input pin.                                                                                                     |  |  |  |
|                                 | Extended serial mode                     |          |                                                                                                                            |  |  |  |
|                                 | RXDX12 Inpu                              |          | Input pin for data reception by SCIf.                                                                                      |  |  |  |
|                                 | TXDX12                                   | Output   | Output pin for data transmission by SCIf.                                                                                  |  |  |  |
|                                 | SIOX12                                   | I/O      | Input/output pin for data reception or transmission by SCIf.                                                               |  |  |  |
| I <sup>2</sup> C bus interface  | SCL0                                     | I/O      | Input/output pin for I <sup>2</sup> C bus interface clocks. Bus can be directly driven by the N-channel open drain output. |  |  |  |
|                                 | SDA0                                     | I/O      | Input/output pin for I <sup>2</sup> C bus interface data. Bus can be directly driven by the N-channel open drain output.   |  |  |  |
| Serial peripheral               | RSPCKA                                   | I/O      | Input/output pin for the RSPI clock.                                                                                       |  |  |  |
| interface                       | MOSIA                                    | I/O      | Input/output pin for transmitting data from the RSPI master.                                                               |  |  |  |
|                                 | MISOA                                    | I/O      | Input/output pin for transmitting data from the RSPI slave.                                                                |  |  |  |
|                                 | SSLA0                                    | I/O      | Input/output pin to select the slave for the RSPI.                                                                         |  |  |  |
|                                 | SSLA1 to SSLA3                           | Output   | Output pins to select the slave for the RSPI.                                                                              |  |  |  |
| 12-bit A/D converter            | AN000 to AN004, AN006,<br>AN008 to AN015 | Input    | Input pins for the analog signals to be processed by the A/D converter.                                                    |  |  |  |
|                                 | ADTRG0#                                  | Input    | Input pin for the external trigger signals that start the A/D conversion.                                                  |  |  |  |
| I/O ports                       | P03, P05                                 | I/O      | 2-bit input/output pins.                                                                                                   |  |  |  |
|                                 | P14 to P17                               | I/O      | 4-bit input/output pins.                                                                                                   |  |  |  |
|                                 | P26, P27                                 | I/O      | 2-bit input/output pins.                                                                                                   |  |  |  |
|                                 | P30 to P32, P35                          | I/O      | 4-bit input/output pins (P35 input pin).                                                                                   |  |  |  |
|                                 | P40 to P44, P46                          | I/O      | 6-bit input/output pins.                                                                                                   |  |  |  |
|                                 | P54, P55                                 | I/O      | 2-bit input/output pins.                                                                                                   |  |  |  |
|                                 | PA0, PA1, PA3, PA4, PA6                  | I/O      | 5-bit input/output pins.                                                                                                   |  |  |  |
|                                 | PB0, PB1, PB3, PB5 to PB7                | I/O      | 6-bit input/output pins.                                                                                                   |  |  |  |

Table 1.4 Pin Functions (3/3)

| Classifications | Pin Name   | I/O   | Description              |
|-----------------|------------|-------|--------------------------|
| I/O ports       | PC0 to PC7 | I/O   | 8-bit input/output pins. |
|                 | PE0 to PE7 | I/O   | 8-bit input/output pins. |
|                 | PH0 to PH3 | I/O   | 4-bit input/output pins. |
|                 | PH7        | Input | 1-bit input pin.         |
|                 | PJ6, PJ7   | I/O   | 2-bit input/output pins. |

Note 1. For external clock input.

# 1.5 Pin Assignments

Figure 1.3 to Figure 1.7 show the pin assignments. Table 1.5 to Table 1.9 show the lists of pins and pin functions.



Figure 1.3 Pin Assignments of the 64-Pin LFQFP/LQFP



Figure 1.4 Pin Assignments of the 64-Pin WFLGA



Figure 1.5 Pin Assignments of the 48-Pin LFQFP/HWQFN



Figure 1.6 Pin Assignments of the 40-Pin HWQFN



Note: This figure indicates the power supply pins and I/O port pins. For the pin

EXTAL

D

VCL

Ε

VSS

F

configuration, see the table "List of Pins and Pin Functions (36-Pin WFLGA)".

Note: For the position of A1 pin in the package, see "Package Dimensions".

XTAL

C

Figure 1.7 Pin Assignments of the 36-Pin WFLGA

AVSS0

Α

RES#

В

1

Table 1.5 List of Pins and Pin Functions (64-Pin LFQFP/LQFP) (1/2)

| Pin<br>No. | Power Supply, Clock,<br>System Control | I/O Port | Timers (MTU, RTC)          | Communication<br>(SCIe, SCIf, RSPI, RIIC)                     | Others                       |
|------------|----------------------------------------|----------|----------------------------|---------------------------------------------------------------|------------------------------|
| 1          |                                        | P03      |                            |                                                               |                              |
| 2          |                                        | P27      | MTIOC2B                    | SCK1/SCK12                                                    | IRQ3/CMPA2/<br>CACREF/ADTRG0 |
| 3          |                                        | P26      | MTIOC2A                    | TXD1/SMOSI1/SSDA1                                             |                              |
| 4          |                                        | P30      |                            | RXD1/SMISO1/SSCL1                                             | IRQ0                         |
| 5          |                                        | P31      |                            | CTS1#/RTS1#/SS1#                                              | IRQ1                         |
| 6          | MD                                     |          |                            |                                                               | FINED                        |
| 7          | RES#                                   |          |                            |                                                               |                              |
| 8          | XCOUT                                  |          |                            |                                                               |                              |
| 9          | XCIN                                   | PH7      |                            |                                                               |                              |
| 10         |                                        | P35      |                            |                                                               | NMI                          |
| 11         | XTAL                                   |          |                            |                                                               |                              |
| 12         | EXTAL                                  |          |                            |                                                               |                              |
| 13         | VCL                                    |          |                            |                                                               |                              |
| 14         | VSS                                    |          |                            |                                                               |                              |
| 15         | VCC                                    |          |                            |                                                               |                              |
| 16         |                                        | P32      | MTIOC0C/RTCOUT             |                                                               | IRQ2                         |
| 17         |                                        | P17      | MTIOCOC                    | SCK1/MISOA/SDA0/RXD12/RXDX12/<br>SMISO12/SSCL12               | IRQ7                         |
| 18         |                                        | P16      | RTCOUT                     | TXD1/SMOSI1/SSDA1/MOSIA/SCL0                                  | IRQ6/ADTRG0#                 |
| 19         |                                        | P15      | MTIOC0B/MTCLKB             | RXD1/SMISO1/SSCL1/RSPCKA                                      | IRQ5/CLKOUT                  |
| 20         |                                        | P14      | MTIOC0A/MTCLKA             | CTS1#/RTS1#/SS1#/SSLA0/TXD12/<br>TXDX12/SIOX12/SMOSI12/SSDA12 | IRQ4                         |
| 21         |                                        | PH3      | MTIOC1A                    |                                                               |                              |
| 22         |                                        | PH2      |                            |                                                               | IRQ1                         |
| 23         |                                        | PH1      |                            |                                                               | IRQ0                         |
| 24         |                                        | PH0      | MTIOC1B                    |                                                               | CACREF                       |
| 25         |                                        | P55      |                            |                                                               |                              |
| 26         |                                        | P54      |                            |                                                               |                              |
| 27         |                                        | PC7      | MTCLKB                     | TXD1/SMOSI1/SSDA1/MISOA                                       | CACREF                       |
| 28         |                                        | PC6      | MTCLKA                     | RXD1/SMISO1/SSCL1/MOSIA                                       |                              |
| 29         |                                        | PC5      | MTCLKD                     | SCK1/RSPCKA                                                   |                              |
| 30         |                                        | PC4      | MTCLKC                     | SCK5/SSLA0                                                    | IRQ2/CLKOUT                  |
| 31         |                                        | PC3      |                            | TXD5/SMOSI5/SSDA5                                             |                              |
| 32         |                                        | PC2      |                            | RXD5/SMISO5/SSCL5/SSLA3                                       |                              |
| 33         |                                        | PB7/PC1  |                            |                                                               |                              |
| 34         |                                        | PB6/PC0  |                            |                                                               |                              |
| 35         |                                        | PB5      | MTIOC2A/MTIOC1B            |                                                               |                              |
| 36         |                                        | PB3      | MTIOC0A                    |                                                               |                              |
| 37         |                                        | PB1      | MTIOC0C                    |                                                               | IRQ4                         |
| 38         | VCC                                    |          |                            |                                                               |                              |
| 39         |                                        | PB0      | MTIC5W/MTIOC0C/<br>RTCOUT  | SCL0/RSPCKA                                                   | IRQ2/ADTRG0#                 |
| 40         | VSS                                    |          |                            |                                                               |                              |
| 41         |                                        | PA6      | MTIC5V/MTCLKB/MTIOC2A      | CTS5#/RTS5#/SS5#/SDA0/MOSIA                                   | IRQ3                         |
| 42         |                                        | PA4      | MTIC5U/MTCLKA/MTIOC2B      | TXD5/SMOSI5/SSDA5/SSLA0                                       | IRQ5                         |
| 43         |                                        | PA3      | MTIOC0D/MTCLKD/<br>MTIOC1B | RXD5/SMISO5/SSCL5/MISOA                                       | IRQ6                         |
| 44         |                                        | PA1      | MTIOC0B/MTCLKC/<br>RTCOUT  | SCK5/SSLA2                                                    |                              |

Table 1.5 List of Pins and Pin Functions (64-Pin LFQFP/LQFP) (2/2)

| Pin | Power Supply, Clock, | 1/0 D .           | T: (4TH DTO)      | Communication                          |            |
|-----|----------------------|-------------------|-------------------|----------------------------------------|------------|
| No. | System Control       | I/O Port          | Timers (MTU, RTC) | (SCIe, SCIf, RSPI, RIIC)               | Others     |
| 45  |                      | PA0               |                   | SSLA1                                  | CACREF     |
| 46  |                      | PE5               | MTIOC2B           |                                        | IRQ5/AN013 |
| 47  |                      | PE4               | MTIOC1A           | MOSIA                                  | IRQ4/AN012 |
| 48  |                      | PE3               | MTIOC0A/MTIOC1B   | CTS12#/RTS12#/SS12#/RSPCKA             | IRQ3/AN011 |
| 49  |                      | PE2               |                   | RXD12/RXDX12/SMISO12/SSCL12            | IRQ7/AN010 |
| 50  |                      | PE1               |                   | TXD12/TXDX12/SIOX12/SMOSI12/<br>SSDA12 | IRQ1/AN009 |
| 51  |                      | PE0               | MTIOC2A           | SCK12                                  | IRQ0/AN008 |
| 52  |                      | PE7               |                   |                                        | IRQ7/AN015 |
| 53  |                      | PE6               |                   |                                        | IRQ6/AN014 |
| 54  |                      | P46*1             |                   |                                        | AN006      |
| 55  |                      | P44*1             |                   |                                        | AN004      |
| 56  |                      | P43*1             |                   |                                        | AN003      |
| 57  |                      | P42*1             |                   |                                        | AN002      |
| 58  |                      | P41* <sup>1</sup> |                   |                                        | AN001      |
| 59  | VREFL0               | PJ7*1             |                   |                                        |            |
| 60  |                      | P40*1             |                   |                                        | AN000      |
| 61  | VREFH0               | PJ6*1             |                   |                                        |            |
| 62  | AVSS0                |                   |                   |                                        |            |
| 63  | AVCC0                |                   |                   |                                        |            |
| 64  |                      | P05               |                   |                                        |            |

Table 1.6 List of Pins and Pin Functions (64-Pin WFLGA) (1/2)

| Pin<br>No. | Power Supply, Clock,<br>System Control | I/O Port          | Timers (MTU, RTC)          | Communication (SCIe, SCIf, RSPI, RIIC)                            | Others                        |
|------------|----------------------------------------|-------------------|----------------------------|-------------------------------------------------------------------|-------------------------------|
| A1         | AVSS0                                  |                   |                            |                                                                   |                               |
| A2         | AVCC0                                  |                   |                            |                                                                   |                               |
| A3         | VREFH0                                 | PJ6* <sup>1</sup> |                            |                                                                   |                               |
| A4         | VREFL0                                 | PJ7* <sup>1</sup> |                            |                                                                   |                               |
| A5         |                                        | P43*1             |                            |                                                                   | AN003                         |
| A6         |                                        | P46*1             |                            |                                                                   | AN006                         |
| A7         |                                        | PE2               |                            | RXD12/RXDX12/SMISO12/SSCL12                                       | IRQ7/AN010                    |
| A8         |                                        | PE3               | MTIOC0A/MTIOC1B            | CTS12#/RTS12#/SS12#/RSPCKA                                        | IRQ3/AN011                    |
| B1         | XCOUT                                  |                   |                            |                                                                   |                               |
| B2         |                                        | P03               |                            |                                                                   |                               |
| В3         |                                        | P40*1             |                            |                                                                   | AN000                         |
| B4         |                                        | P42*1             |                            |                                                                   | AN002                         |
| B5         |                                        | P44*1             |                            |                                                                   | AN004                         |
| B6         |                                        | PE6               |                            |                                                                   | IRQ6/AN014                    |
| B7         |                                        | PE1               |                            | TXD12/TXDX12/SIOX12/SMOSI12/<br>SSDA12                            | IRQ1/AN009                    |
| B8         |                                        | PE4               | MTIOC1A                    | MOSIA                                                             | IRQ4/AN012                    |
| C1         | XCIN                                   | PH7               |                            |                                                                   |                               |
| C2         |                                        | P05               |                            |                                                                   |                               |
| C3         |                                        | P27               | MTIOC2B                    | SCK1/SCK12                                                        | IRQ3/CMPA2/<br>CACREF/ADTRG0; |
| C4         |                                        | P41* <sup>1</sup> |                            |                                                                   | AN001                         |
| C5         |                                        | PE7               |                            |                                                                   | IRQ7/AN015                    |
| C6         |                                        | PE5               | MTIOC2B                    |                                                                   | IRQ5/AN013                    |
| C7         |                                        | PA1               | MTIOC0B/MTCLKC/<br>RTCOUT  | SCK5/SSLA2                                                        |                               |
| C8         |                                        | PA0               |                            | SSLA1                                                             | CACREF                        |
| D1         | RES#                                   |                   |                            |                                                                   |                               |
| D2         |                                        | P30               |                            | RXD1/SMISO1/SSCL1                                                 | IRQ0                          |
| D3         |                                        | P26               | MTIOC2A                    | TXD1/SMOSI1/SSDA1                                                 |                               |
| D4         |                                        | PE0               | MTIOC2A                    | SCK12                                                             | IRQ0/AN008                    |
| D5         |                                        | PA6               | MTIC5V/MTIOC2A/MTCLKB      | CTS5#/RTS5#/SS5#/SDA0/MOSIA                                       | IRQ3                          |
| D6         |                                        | PA4               | MTIC5U/MTIOC2B/MTCLKA      | TXD5/SMOSI5/SSDA5/SSLA0                                           | IRQ5                          |
| D7         |                                        | PA3               | MTIOC0D/MTCLKD/<br>MTIOC1B | RXD5/SMISO5/SSCL5/MISOA                                           | IRQ6                          |
| D8         | VSS                                    |                   |                            |                                                                   |                               |
| E1         | XTAL                                   |                   |                            |                                                                   |                               |
| E2         | MD                                     |                   |                            |                                                                   | FINED                         |
| E3         |                                        | P31               |                            | CTS1#/RTS1#/SS1#                                                  | IRQ1                          |
| E4         |                                        | P55               |                            |                                                                   |                               |
| E5         |                                        | PB3               | MTIOC0A                    |                                                                   |                               |
| E6         |                                        | PB1               | MTIOC0C                    |                                                                   | IRQ4                          |
| E7         |                                        | PB0               | MTIC5W/MTIOC0C/<br>RTCOUT  | SCL0/RSPCKA                                                       | IRQ2/ADTRG0#                  |
| E8         | VCC                                    |                   |                            |                                                                   |                               |
| F1         | EXTAL                                  |                   |                            |                                                                   |                               |
| F2         |                                        | P32               | MTIOC0C/RTCOUT             |                                                                   | IRQ2                          |
| F3         |                                        | P35               |                            |                                                                   | NMI                           |
| F4         |                                        | P14               | MTIOC0A/MTCLKA             | CTS1#/RTS1#/SS1#/TXD12/<br>TXDX12/SIOX12/SMOSI12/SSDA12/<br>SSLA0 | IRQ4                          |

Table 1.6 List of Pins and Pin Functions (64-Pin WFLGA) (2/2)

| Pin<br>No. | Power Supply, Clock,<br>System Control | I/O Port | Timers (MTU, RTC) | Communication<br>(SCIe, SCIf, RSPI, RIIC)       | Others       |
|------------|----------------------------------------|----------|-------------------|-------------------------------------------------|--------------|
| F5         |                                        | P54      |                   |                                                 |              |
| F6         |                                        | PC7      | MTCLKB            | TXD1/SMOSI1/SSDA1/MISOA                         | CACREF       |
| F7         |                                        | PC4      | MTCLKC            | SCK5/SSLA0                                      | IRQ2/CLKOUT  |
| F8         |                                        | PB5      | MTIOC1B/MTIOC2A   |                                                 |              |
| G1         | VCL                                    |          |                   |                                                 |              |
| G2         |                                        | P17      | MTIOC0C           | SCK1/MISOA/SDA0/RXD12/RXDX12/<br>SMISO12/SSCL12 | IRQ7         |
| G3         |                                        | P16      | RTCOUT            | TXD1/SMOSI1/SSDA1/SCL0/MOSIA                    | IRQ6/ADTRG0# |
| G4         |                                        | P15      | MTIOC0B/MTCLKB    | RXD1/SMISO1/SSCL1/RSPCKA                        | IRQ5/CLKOUT  |
| G5         |                                        | PC6      | MTCLKA            | RXD1/SMISO1/SSCL1/MOSIA                         |              |
| G6         |                                        | PC5      | MTCLKD            | SCK1/RSPCKA                                     |              |
| G7         |                                        | PC3      |                   | TXD5/SMOSI5/SSDA5                               |              |
| G8         |                                        | PB6/PC0  |                   |                                                 |              |
| H1         | VSS                                    |          |                   |                                                 |              |
| H2         | VCC                                    |          |                   |                                                 |              |
| НЗ         |                                        | PH3      | MTIOC1A           |                                                 |              |
| H4         |                                        | PH2      |                   |                                                 | IRQ1         |
| H5         |                                        | PH1      |                   |                                                 | IRQ0         |
| H6         |                                        | PH0      | MTIOC1B           |                                                 | CACREF       |
| H7         |                                        | PC2      |                   | RXD5/SMISO5/SSCL5/SSLA3                         |              |
| H8         |                                        | PB7/PC1  |                   |                                                 |              |

Table 1.7 List of Pins and Pin Functions (48-Pin LFQFP/HWQFN) (1/2)

| Pin<br>No. | Power Supply, Clock,<br>System Control | I/O Port   | Timers (MTU, RTC)                      | Communication (SCIe, SCIf, RSPI, RIIC)                        | Others                        |
|------------|----------------------------------------|------------|----------------------------------------|---------------------------------------------------------------|-------------------------------|
| 1          |                                        | P27        | MTIOC2B                                | SCK1/SCK12                                                    | IRQ3/CMPA2/<br>CACREF/ADTRG0# |
| 2          |                                        | P26        | MTIOC2A                                | TXD1/SMOSI1/SSDA1                                             |                               |
| 3          | MD                                     |            |                                        |                                                               | FINED                         |
| 4          | RES#                                   |            |                                        |                                                               |                               |
| 5          | XCOUT                                  |            |                                        |                                                               |                               |
| 6          | XCIN                                   | PH7        |                                        |                                                               |                               |
| 7          |                                        | P35        |                                        |                                                               | NMI                           |
| 8          | XTAL                                   |            |                                        |                                                               |                               |
| 9          | EXTAL                                  |            |                                        |                                                               |                               |
| 10         | VCL                                    |            |                                        |                                                               |                               |
| 11         | VSS                                    |            |                                        |                                                               |                               |
| 12         | VCC                                    |            |                                        |                                                               |                               |
| 13         |                                        | P17        | MTIOC0C                                | SCK1/MISOA/SDA0/RXD12/RXDX12/<br>SMISO12/SSCL12               | IRQ7                          |
| 14         |                                        | P16        | RTCOUT                                 | TXD1/SMOSI1/SSDA1/MOSIA/SCL0                                  | IRQ6/ADTRG0#                  |
| 15         |                                        | P15        | MTIOC0B/MTCLKB                         | RXD1/SMISO1/SSCL1/RSPCKA                                      | IRQ5/CLKOUT                   |
| 16         |                                        | P14        | MTIOC0A/MTCLKA                         | CTS1#/RTS1#/SS1#/SSLA0/TXD12/<br>TXDX12/SIOX12/SMOSI12/SSDA12 | IRQ4                          |
| 17         |                                        | PH3        | MTIOC1A                                |                                                               |                               |
| 18         |                                        | PH2        |                                        |                                                               | IRQ1                          |
| 19         |                                        | PH1        |                                        |                                                               | IRQ0                          |
| 20         |                                        | PH0        | MTIOC1B                                |                                                               | CACREF                        |
| 21         |                                        | PC7        | MTCLKB                                 | TXD1/SMOSI1/SSDA1/MISOA                                       | CACREF                        |
| 22         |                                        | PC6        | MTCLKA                                 | RXD1/SMISO1/SSCL1/MOSIA                                       |                               |
| 23         |                                        | PC5        | MTCLKD                                 | SCK1/RSPCKA                                                   |                               |
| 24         |                                        | PC4        | MTCLKC                                 | SCK5/SSLA0                                                    | IRQ2/CLKOUT                   |
| 25         |                                        | PB5/PC3    | MTIOC2A/MTIOC1B                        |                                                               |                               |
| 26         |                                        | PB3/PC2    | MTIOC0A                                |                                                               |                               |
| 27         |                                        | PB1/PC1    | MTIOC0C                                |                                                               | IRQ4                          |
| 28         | VCC                                    |            |                                        |                                                               |                               |
| 29         |                                        | PB0/PC0    | MTIC5W/MTIOC0C/<br>RTCOUT              | SCL0/RSPCKA                                                   | IRQ2/ADTRG0#                  |
| 30         | VSS                                    | D10        | A ATTIONNY MATRICINES                  | 0707 1/0707 1/007 1/007 1/0001                                | 1000                          |
| 31         |                                        | PA6        | MTIC5V/MTCLKB/MTIOC2A                  | CTS5#/RTS5#/SS5#/SDA0/MOSIA                                   | IRQ3                          |
| 32         |                                        | PA4<br>PA3 | MTIC5U/MTCLKA/MTIOC2B  MTIOC0D/MTCLKD/ | TXD5/SMOSI5/SSDA5/SSLA0  RXD5/SMISO5/SSCL5/MISOA              | IRQ5<br>IRQ6                  |
| 34         |                                        | PA1        | MTIOC1B  MTIOC0B/MTCLKC/ RTCOUT        | SCK5/SSLA2                                                    |                               |
| 35         |                                        | PE4        | MTIOC1A                                | MOSIA                                                         | IRQ4/AN012                    |
| 36         |                                        | PE3        | MTIOC0A/MTIOC1B                        | CTS12#/RTS12#/SS12#/RSPCKA                                    | IRQ3/AN012                    |
| 37         |                                        | PE2        |                                        | RXD12/RXDX12/SMISO12/SSCL12                                   | IRQ7/AN010                    |
| 38         |                                        | PE1        |                                        | TXD12/TXDX12/SIOX12/SMOSI12/<br>SSDA12                        | IRQ1/AN009                    |
| 39         |                                        | PE0        | MTIOC2A                                | SCK12                                                         | IRQ0/AN008                    |
| 40         |                                        | PE7        |                                        |                                                               | IRQ7/AN015                    |
| 41         |                                        | P46*1      |                                        |                                                               | AN006                         |
| 42         |                                        | P42*1      |                                        |                                                               | AN002                         |
| 43         |                                        | P41*1      |                                        |                                                               | AN001                         |
| 44         | VREFL0                                 | PJ7*1      |                                        |                                                               |                               |

Table 1.7 List of Pins and Pin Functions (48-Pin LFQFP/HWQFN) (2/2)

| Pin | Power Supply, Clock, |          |                   | Communication            |        |
|-----|----------------------|----------|-------------------|--------------------------|--------|
| No. | System Control       | I/O Port | Timers (MTU, RTC) | (SCIe, SCIf, RSPI, RIIC) | Others |
| 45  |                      | P40*1    |                   |                          | AN000  |
| 46  | VREFH0               | PJ6*1    |                   |                          |        |
| 47  | AVSS0                |          |                   |                          |        |
| 48  | AVCC0                |          |                   |                          |        |

Table 1.8 List of Pins and Pin Functions (40-Pin HWQFN)

| Pin<br>No. | Power Supply, Clock,<br>System Control | I/O Port          | Timers (MTU, RTC)          | Communication (SCIe, SCIf, RSPI, RIIC)                        | Others                        |
|------------|----------------------------------------|-------------------|----------------------------|---------------------------------------------------------------|-------------------------------|
| 1          |                                        | P27               | MTIOC2B                    | SCK1/SCK12                                                    | IRQ3/CMPA2/<br>CACREF/ADTRG0: |
| 2          |                                        | P26               | MTIOC2A                    | TXD1/SMOSI1/SSDA1                                             |                               |
| 3          | MD                                     |                   |                            |                                                               | FINED                         |
| 4          | RES#                                   |                   |                            |                                                               |                               |
| 5          |                                        | P35               |                            |                                                               | NMI                           |
| 6          | XTAL                                   |                   |                            |                                                               |                               |
| 7          | EXTAL                                  |                   |                            |                                                               |                               |
| 8          | VCL                                    |                   |                            |                                                               |                               |
| 9          | VSS                                    |                   |                            |                                                               |                               |
| 10         | VCC                                    |                   |                            |                                                               |                               |
| 11         |                                        | P32               | MTIOC0C                    |                                                               | IRQ2                          |
| 12         |                                        | P17               | MTIOC0C                    | SCK1/MISOA/SDA0/RXD12/RXDX12/<br>SMISO12/SSCL12               | IRQ7                          |
| 13         |                                        | P16               |                            | TXD1/SMOSI1/SSDA1/SCL0/MOSIA                                  | IRQ6/ADTRG0#                  |
| 14         |                                        | P15               | MTIOC0B/MTCLKB             | RXD1/SMISO1/SSCL1/RSPCKA                                      | IRQ5/CLKOUT                   |
| 15         |                                        | P14               | MTIOC0A/MTCLKA             | CTS1#/RTS1#/SS1#/SSLA0/TXD12/<br>TXDX12/SIOX12/SMOSI12/SSDA12 | IRQ4                          |
| 16         |                                        | PH3               | MTIOC1A                    |                                                               |                               |
| 17         |                                        | PH2               |                            |                                                               | IRQ1                          |
| 18         |                                        | PH1               |                            |                                                               | IRQ0                          |
| 19         |                                        | PH0               | MTIOC1B                    |                                                               | CACREF                        |
| 20         |                                        | PC4               | MTCLKC                     | SCK5/SSLA0                                                    | IRQ2/CLKOUT                   |
| 21         |                                        | PB3               | MTIOC0A                    |                                                               |                               |
| 22         | VCC                                    |                   |                            |                                                               |                               |
| 23         |                                        | PB0               | MTIOC0C/MTIC5W             | SCL0/RSPCKA                                                   | IRQ2/ADTRG0#                  |
| 24         | VSS                                    |                   |                            |                                                               |                               |
| 25         |                                        | PA6               | MTIOC2A/MTIC5V/MTCLKB      | CTS5#/RTS5#/SS5#/SDA0/MOSIA                                   | IRQ3                          |
| 26         |                                        | PA4               | MTIOC2B/MTIC5U/MTCLKA      | TXD5/SMOSI5/SSDA5/SSLA0                                       | IRQ5                          |
| 27         |                                        | PA3               | MTIOC0D/MTIOC1B/<br>MTCLKD | RXD5/SMISO5/SSCL5/MISOA                                       | IRQ6                          |
| 28         |                                        | PA1               | MTIOC0B/MTCLKC             | SCK5/SSLA2                                                    |                               |
| 29         |                                        | PE4               | MTIOC1A                    | MOSIA                                                         | IRQ4/AN012                    |
| 30         |                                        | PE3               | MTIOC0A/MTIOC1B            | CTS12#/RTS12#/SS12#/RSPCKA                                    | IRQ3/AN011                    |
| 31         |                                        | PE2               |                            | RXD12/RXDX12/SMISO12/SSCL12                                   | IRQ7/AN010                    |
| 32         |                                        | PE1               |                            | TXD12/TXDX12/SIOX12/SMOSI12/<br>SSDA12                        | IRQ1/AN009                    |
| 33         |                                        | PE0               | MTIOC2A                    | SCK12                                                         | IRQ0/AN008                    |
| 34         |                                        | P46*1             |                            |                                                               | AN006                         |
| 35         |                                        | P42*1             |                            |                                                               | AN002                         |
| 36         |                                        | P41* <sup>1</sup> |                            |                                                               | AN001                         |
| 37         | VREFL0                                 | PJ7*1             |                            |                                                               |                               |
| 38         | VREFH0                                 | PJ6*1             |                            |                                                               |                               |
| 39         | AVSS0                                  | _                 |                            |                                                               |                               |

Table 1.9 List of Pins and Pin Functions (36-Pin WFLGA)

| Pin<br>No. | Power Supply, Clock, System Control | I/O Port | Timers (MTU, RTC)          | Communication (SCIe, SCIf, RSPI, RIIC)                        | Others                       |
|------------|-------------------------------------|----------|----------------------------|---------------------------------------------------------------|------------------------------|
| A1         | AVSS0                               |          |                            |                                                               |                              |
| A2         | AVCC0                               |          |                            |                                                               |                              |
| A3         | VREFH0                              | PJ6*1    |                            |                                                               |                              |
| A4         |                                     | P42*1    |                            |                                                               | AN002                        |
| A5         |                                     | P41*1    |                            |                                                               | AN001                        |
| A6         |                                     | PE2      |                            | RXD12/RXDX12/SMISO12/SSCL12                                   | IRQ7/AN010                   |
| B1         | RES#                                |          |                            |                                                               |                              |
| B2         |                                     | P27      | MTIOC2B                    | SCK1/SCK12                                                    | IRQ3/CMPA2/<br>CACREF/ADTRG0 |
| В3         | VREFL0                              | PJ7*1    |                            |                                                               |                              |
| B4         |                                     | PE0      | MTIOC2A                    | SCK12                                                         | IRQ0/AN008                   |
| B5         |                                     | PE1      |                            | TXD12/TXDX12/SIOX12/SMOSI12/<br>SSDA12                        | IRQ1/AN009                   |
| B6         |                                     | PA3      | MTIOC0D/MTCLKD/<br>MTIOC1B | RXD5/SMISO5/SSCL5/MISOA                                       | IRQ6                         |
| C1         | XTAL                                |          |                            |                                                               |                              |
| C2         | MD                                  |          |                            |                                                               | FINED                        |
| СЗ         |                                     | PE3      | MTIOC0A/MTIOC1B            | CTS12#/RTS12#/SS12#/RSPCKA                                    | IRQ3/AN011                   |
| C4         |                                     | PE4      | MTIOC1A                    | MOSIA                                                         | IRQ4/AN012                   |
| C5         |                                     | PA4      | MTIOC2B/MTIC5U/MTCLKA      | TXD5/SMOSI5/SSDA5/SSLA0                                       | IRQ5                         |
| C6         | VSS                                 |          |                            |                                                               |                              |
| D1         | EXTAL                               |          |                            |                                                               |                              |
| D2         |                                     | P35      |                            |                                                               | NMI                          |
| D3         |                                     | P14      | MTIOC0A/MTCLKA             | CTS1#/RTS1#/SS1#/SSLA0/TXD12/<br>TXDX12/SIOX12/SMOSI12/SSDA12 | IRQ4                         |
| D4         |                                     | PA6      | MTIC5V/MTCLKB/MTIOC2A      | CTS5#/RTS5#/SS5#/SDA0/MOSIA                                   | IRQ3                         |
| D5         |                                     | PB3      | MTIOC0A                    |                                                               |                              |
| D6         |                                     | PB0      | MTIOC0C/MTIC5W             | SCL0/RSPCKA                                                   | IRQ2/ADTRG0#                 |
| E1         | VCL                                 |          |                            |                                                               |                              |
| E2         |                                     | P17      | MTIOC0C                    | SCK1/MISOA/SDA0/RXD12/RXDX12/<br>SMISO12/SSCL12               | IRQ7                         |
| E3         |                                     | P16      |                            | TXD1/SMOSI1/SSDA1/SCL0/MOSIA                                  | IRQ6/ADTRG0#                 |
| E4         |                                     | P15      | MTIOC0B/MTCLKB             | RXD1/SMISO1/SSCL1/RSPCKA                                      | IRQ5/CLKOUT                  |
| E5         |                                     | PC4      | MTCLKC                     | SCK5/SSLA0                                                    | IRQ2/CLKOUT                  |
| E6         | VCC                                 |          |                            |                                                               |                              |
| F1         | VSS                                 |          |                            |                                                               |                              |
| F2         | VCC                                 |          |                            |                                                               |                              |
| F3         |                                     | PH3      | MTIOC1A                    |                                                               |                              |
| F4         |                                     | PH2      |                            |                                                               | IRQ1                         |
| F5         |                                     | PH1      |                            |                                                               | IRQ0                         |
| F6         |                                     | PH0      | MTIOC1B                    |                                                               | CACREF                       |

#### CPU

This MCU has the RX CPU as its core.

A variable-length instruction format has been adopted for the RX CPU. Allocating the more frequently used instructions to the shorter instruction lengths facilitates the development of efficient programs that take up less memory. The CPU has 73 basic instructions and nine DSP instructions, for a total of 82 instructions. It has 10 addressing modes and caters to register-to-register operations, register-to-memory operations, immediate-to-register operations, immediate-to-memory operations, memory-to-memory transfer, and bitwise operations. In a single cycle, high-speed calculation is attained for not just register-to-register operations, but also for other types of combined instructions. The CPU includes an internal multiplier and an internal divider for high-speed multiplication and division.

The RX CPU has a five-stage pipeline for processing instructions. The stages are instruction fetching, decoding, execution, memory access, and write back. In cases where pipeline processing is drawn out by memory access.

The RX CPU has a five-stage pipeline for processing instructions. The stages are instruction fetching, decoding, execution, memory access, and write-back. In cases where pipeline processing is drawn-out by memory access, subsequent operations may in fact be executed earlier. By adopting an "out-of-order completion" of this kind, instruction execution is controlled to optimize the number of clock cycles.

#### 2.1 Features

• Minimum instruction execution rate: One instruction per clock cycle

• Address space: 4-Gbyte linear

• Register set of the CPU

General purpose: Sixteen 32-bit registers

Control: Eight 32-bit registers Accumulator: One 64-bit register

 Basic instructions: 73 (arithmetic/logic instructions, data-transfer instructions, branch instructions, bit-manipulation instructions, string-manipulation instructions, and system-manipulation instructions)

Relative branch instructions to suit branch distances

Variable-length instruction format (lengths from 1 to 8 bytes)

Short formats for frequently used instructions

• DSP instructions: 9

Supports 16-bit × 16-bit multiplication and multiply-and-accumulate operations.

Rounds the data in the accumulator.

- Addressing modes: 10
- Five-stage pipeline

Adoption of "out-of-order completion"

• Processor modes

A supervisor mode and a user mode are supported.

• Data arrangement

Selectable as little endian or big endian

# 2.2 Register Set of the CPU

The RX CPU has 16 general-purpose registers, eight control registers, and one accumulator used for DSP instructions.



Figure 2.1 Register Set of the CPU

### 2.2.1 General-Purpose Registers (R0 to R15)

This CPU has 16 general-purpose registers (R0 to R15). R0 to R15 can be used as data registers or address registers. R0, a general-purpose register, also functions as the stack pointer (SP). The stack pointer is switched to operate as the interrupt stack pointer (ISP) or user stack pointer (USP) by the value of the stack pointer select bit (U) in the processor status word (PSW).

### 2.2.2 Control Registers

This CPU has the following eight control registers.

- Interrupt stack pointer (ISP)
- User stack pointer (USP)
- Interrupt table register (INTB)
- Program counter (PC)
- Processor status word (PSW)
- Backup PC (BPC)
- Backup PSW (BPSW)
- Fast interrupt vector register (FINTV)

# 2.2.2.1 Interrupt Stack Pointer (ISP)/User Stack Pointer (USP)



The stack pointer (SP) can be either of two types, the interrupt stack pointer (ISP) or the user stack pointer (USP). Whether the stack pointer operates as the ISP or USP depends on the value of the stack pointer select bit (U) in the processor status word (PSW).

Set the ISP or USP to a multiple of 4, as this reduces the numbers of cycles required to execute interrupt sequences and instructions entailing stack manipulation.

# 2.2.2.2 Interrupt Table Register (INTB)



value after reset: Undefined

The interrupt table register (INTB) specifies the address where the relocatable vector table starts.

# 2.2.2.3 Program Counter (PC)



The program counter (PC) indicates the address of the instruction being executed.

# 2.2.2.4 Processor Status Word (PSW)



| Bit        | Symbol          | Bit Name                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W |
|------------|-----------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0         | С               | Carry Flag                         | O: No carry has occurred. A carry has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                | R/W |
| b1         | Z               | Zero Flag                          | 0: Result is not 0. 1: Result is 0.                                                                                                                                                                                                                                                                                                                                                                                                                            | R/W |
| b2         | S               | Sign Flag                          | Result is a positive value or 0.     Result is a negative value.                                                                                                                                                                                                                                                                                                                                                                                               | R/W |
| b3         | 0               | Overflow Flag                      | No overflow has occurred.     An overflow has occurred.                                                                                                                                                                                                                                                                                                                                                                                                        | R/W |
| b15 to b4  | _               | Reserved                           | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                                                                                                         | R/W |
| b16        | <b> </b> *1     | Interrupt Enable                   | Interrupt disabled.     Interrupt enabled.                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W |
| b17        | U* <sup>1</sup> | Stack Pointer Select               | O: Interrupt stack pointer (ISP) is selected.     User stack pointer (USP) is selected.                                                                                                                                                                                                                                                                                                                                                                        | R/W |
| b19, b18   | _               | Reserved                           | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                                                                                                         | R/W |
| b20        | PM*1,*2,*3      | Processor Mode Select              | Supervisor mode is selected.     User mode is selected.                                                                                                                                                                                                                                                                                                                                                                                                        | R/W |
| b23 to b21 | _               | Reserved                           | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                                                                                                         | R/W |
| b27 to b24 | IPL[3:0]*1      | Processor Interrupt Priority Level | b27 b24 0 0 0 0: Priority level 0 (lowest) 0 0 0 1: Priority level 1 0 0 1 0: Priority level 2 0 0 1 1: Priority level 3 0 1 0 0: Priority level 4 0 1 0 1: Priority level 5 0 1 1 0: Priority level 6 0 1 1 1: Priority level 7 1 0 0 0: Priority level 8 1 0 0 1: Priority level 9 1 0 1 0: Priority level 10 1 0 1 1: Priority level 11 1 1 0 0: Priority level 12 1 1 0 1: Priority level 13 1 1 1 0: Priority level 14 1 1 1: Priority level 15 (highest) | R/W |
| b31 to b28 | _               | Reserved                           | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                                                                                                         | R/W |

Note 1. In user mode, writing to the IPL[3:0], PM, U, and I bits by an MVTC or a POPC instruction is ignored. Writing to the IPL[3:0] bits by an MVTIPL instruction generates a privileged instruction exception.

Note 2. In supervisor mode, writing to the PM bit by an MVTC or a POPC instruction is ignored, but writing to the other bits is possible.

Note 3. Switching from supervisor mode to user mode requires execution of an RTE instruction after having set the PSW.PM bit saved on the stack to 1 or executing an RTFI instruction after having set the BPSW.PM bit to 1.

The processor status word (PSW) indicates the results of instruction execution or the state of the CPU.

#### C Flag (Carry Flag)

This flag indicates whether a carry, borrow, or shift-out has occurred as the result of an operation.

#### Z Flag (Zero Flag)

This flag indicates that the result of an operation was 0.

#### S Flag (Sign Flag)

This flag indicates that the result of an operation was negative.

#### O Flag (Overflow Flag)

This flag indicates that an overflow occurred during an operation.

### I Bit (Interrupt Enable)

This bit enables interrupt requests. When an exception is accepted, this bit becomes 0.

#### **U Bit (Stack Pointer Select)**

This bit specifies the stack pointer as either the ISP or USP. When an exception request is accepted, this bit becomes 0. When the processor mode is switched from supervisor mode to user mode, this bit becomes 1.

#### PM Bit (Processor Mode Select)

This bit specifies the processor mode. When an exception is accepted, this bit becomes 0.

#### IPL[3:0] Bits (Processor Interrupt Priority Level)

The IPL[3:0] bits specify the processor interrupt priority level as one of 16 levels from zero to 15, wherein priority level zero is the lowest and priority level 15 the highest. When the priority level of a requested interrupt is higher than the processor interrupt priority level, the interrupt is enabled. Setting the IPL[3:0] bits to level 15 (Fh) disables all interrupt requests. The IPL[3:0] bits are set to level 15 (Fh) when a non-maskable interrupt is generated. When interrupts are generated, the bits are set to the priority levels of accepted interrupts.

# 2.2.2.5 Backup PC (BPC)



The backup PC (BPC) is provided to speed up response to interrupts.

After a fast interrupt has been generated, the contents of the program counter (PC) are saved in the BPC register.

# 2.2.2.6 Backup PSW (BPSW)



The backup PSW (BPSW) is provided to speed up response to interrupts.

After a fast interrupt has been generated, the contents of the processor status word (PSW) are saved in the BPSW. The allocation of bits in the BPSW corresponds to that in the PSW.

### 2.2.2.7 Fast Interrupt Vector Register (FINTV)



The fast interrupt vector register (FINTV) is provided to speed up response to interrupts.

The FINTV register specifies a branch destination address when a fast interrupt has been generated.

### 2.2.3 Register Associated with DSP Instructions

# 2.2.3.1 Accumulator (ACC)



Value after reset: Undefined

The accumulator (ACC) is a 64-bit register used for DSP instructions. The accumulator is also used for the multiply and multiply-and-accumulate instructions; EMUL, EMULU, MUL, and RMPA, in which case the prior value in the accumulator is modified by execution of the instruction.

Use the MVTACHI and MVTACLO instructions for writing to the accumulator. The MVTACHI and MVTACLO instructions write data to the higher-order 32 bits (bits 63 to 32) and the lower-order 32 bits (bits 31 to 0), respectively. Use the MVFACHI and MVFACHI instructions for reading data from the accumulator. The MVFACHI and MVFACMI instructions read data from the higher-order 32 bits (bits 63 to 32) and the middle 32 bits (bits 47 to 16), respectively.

#### 2.3 Processor Mode

The RX CPU supports two processor modes, supervisor and user. These processor modes enable the realization of a hierarchical CPU resource protection.

Each processor mode imposes a level on rights of access to the CPU resources and the instructions that can be executed. Supervisor mode carries greater rights than those of user mode.

The initial state after a reset is supervisor mode.

### 2.3.1 Supervisor Mode

In supervisor mode, all CPU resources are accessible and all instructions are available. However, writing to the processor mode select bit (PM) in the processor status word (PSW) by executing an MVTC or a POPC instruction will be ignored. For details on how to write to the PM bit, refer to section 2.2.2.4, Processor Status Word (PSW).

#### 2.3.2 User Mode

In user mode, write access to the CPU resources listed below is restricted. The restriction applies to any instruction capable of write access.

- Some bits (bits IPL[3:0], PM, U, and I) in the processor status word (PSW)
- Interrupt stack pointer (ISP)
- Interrupt table register (INTB)
- Backup PSW (BPSW)
- Backup PC (BPC)
- Fast interrupt vector register (FINTV)

#### 2.3.3 Privileged Instruction

Privileged instructions can only be executed in supervisor mode. Executing a privileged instruction in user mode produces a privileged instruction exception. Privileged instructions include the RTFI, MVTIPL, RTE, and WAIT instructions.

#### 2.3.4 Switching between Processor Modes

Manipulating the processor mode select bit (PM) in the processor status word (PSW) switches the processor mode. However, rewriting to the PM bit by executing an MVTC or a POPC instruction is prohibited. Switch the processor mode by following the procedures described below.

#### (1) Switching from user mode to supervisor mode

After an exception occurs, the PSW.PM bit is set to 0 and the CPU switches to supervisor mode. The hardware preprocessing is executed in supervisor mode. The state of the processor mode before the exception was generated is retained in the copy of PSW.PM bit is saved on the stack.

#### (2) Switching from supervisor mode to user mode

Executing an RTE instruction when the value of the copy of the PSW.PM bit that has been preserved on the stack is 1 or an RTFI instruction when the value of the copy of the PSW.PM bit that has been preserved in the backup PSW (BPSW) is 1 causes a transition to user mode. In the transition to user mode, the value of the stack pointer designation bit (the U bit in the PSW) becomes 1.



### 2.4 Data Types

The RX CPU can handle three types of data: integer, bit, and string.

For details, refer to RX Family User's Manual: Software.

#### 2.5 Endian

For the RX CPU, instructions are little endian, but the data arrangement is selectable as little or big endian.

# 2.5.1 Switching the Endian

As arrangements of bytes, this MCU supports both big endian, where the higher-order byte (MSB) is at location 0, and little endian, where the lower-order byte (LSB) is at location 0.

For details on the endian setting, refer to section 3, Operating Modes.

Operations for access differ according to the endian setting and, depending on the instruction, whether 8-, 16- or 32-bit access has been selected. Operations for access in the various possible cases are described in Table 2.1 to Table 2.12. In the tables,

LL indicates bits D7 to D0 of the general-purpose register,

LH indicates bits D15 to D8 of the general-purpose register,

HL indicates bits D23 to D16 of the general-purpose register, and

HH indicates bits D31 to D24 of the general-purpose register.

|                              | D31 to D24 | D23 to D16 | D15 to D8 | D7 to D0 |
|------------------------------|------------|------------|-----------|----------|
| General purpose register: Rm | НН         | HL         | LH        | LL       |

Table 2.1 32-Bit Read Operations when Little Endian has been Selected

| Operation Address of src | Reading a 32-bit unit from address 0 | Reading a 32-bit unit from address 1 | Reading a 32-bit unit from address 2 | Reading a 32-bit unit from address 3 | Reading a 32-bit unit from address 4 |
|--------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|
| Address 0                | Transfer to LL                       | _                                    | _                                    | _                                    | _                                    |
| Address 1                | Transfer to LH                       | Transfer to LL                       | _                                    | _                                    | _                                    |
| Address 2                | Transfer to HL                       | Transfer to LH                       | Transfer to LL                       | _                                    | _                                    |
| Address 3                | Transfer to HH                       | Transfer to HL                       | Transfer to LH                       | Transfer to LL                       | _                                    |
| Address 4                | _                                    | Transfer to HH                       | Transfer to HL                       | Transfer to LH                       | Transfer to LL                       |
| Address 5                | _                                    | _                                    | Transfer to HH                       | Transfer to HL                       | Transfer to LH                       |
| Address 6                | _                                    | _                                    | _                                    | Transfer to HH                       | Transfer to HL                       |
| Address 7                | _                                    | _                                    | _                                    | _                                    | Transfer to HH                       |

Table 2.2 32-Bit Read Operations when Big Endian has been Selected

| Operation Address of src | Reading a 32-bit unit from address 0 | Reading a 32-bit unit from address 1 | Reading a 32-bit unit from address 2 | Reading a 32-bit unit from address 3 | Reading a 32-bit unit from address 4 |
|--------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|
| Address 0                | Transfer to HH                       | _                                    | _                                    | _                                    | _                                    |
| Address 1                | Transfer to HL                       | Transfer to HH                       | _                                    | _                                    | _                                    |
| Address 2                | Transfer to LH                       | Transfer to HL                       | Transfer to HH                       | _                                    | _                                    |
| Address 3                | Transfer to LL                       | Transfer to LH                       | Transfer to HL                       | Transfer to HH                       | _                                    |
| Address 4                | _                                    | Transfer to LL                       | Transfer to LH                       | Transfer to HL                       | Transfer to HH                       |
| Address 5                | _                                    | _                                    | Transfer to LL                       | Transfer to LH                       | Transfer to HL                       |
| Address 6                | _                                    | _                                    | _                                    | Transfer to LL                       | Transfer to LH                       |
| Address 7                | _                                    | _                                    | _                                    | _                                    | Transfer to LL                       |

Table 2.3 32-Bit Write Operations when Little Endian has been Selected

| Operation          |                                    |                                    |                                    |                                    |                                    |
|--------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|
| Address<br>of dest | Writing a 32-bit unit to address 0 | Writing a 32-bit unit to address 1 | Writing a 32-bit unit to address 2 | Writing a 32-bit unit to address 3 | Writing a 32-bit unit to address 4 |
| Address 0          | Transfer from LL                   | _                                  | _                                  | _                                  | _                                  |
| Address 1          | Transfer from LH                   | Transfer from LL                   | _                                  | _                                  | _                                  |
| Address 2          | Transfer from HL                   | Transfer from LH                   | Transfer from LL                   | _                                  | _                                  |
| Address 3          | Transfer from HH                   | Transfer from HL                   | Transfer from LH                   | Transfer from LL                   | _                                  |
| Address 4          | _                                  | Transfer from HH                   | Transfer from HL                   | Transfer from LH                   | Transfer from LL                   |
| Address 5          | _                                  | _                                  | Transfer from HH                   | Transfer from HL                   | Transfer from LH                   |
| Address 6          | _                                  | _                                  | _                                  | Transfer from HH                   | Transfer from HL                   |
| Address 7          | _                                  | _                                  | _                                  | _                                  | Transfer from HH                   |

Table 2.4 32-Bit Write Operations when Big Endian has been Selected

| Operation          |                                    |                                    |                                    |                                    |                                    |
|--------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|
| Address<br>of dest | Writing a 32-bit unit to address 0 | Writing a 32-bit unit to address 1 | Writing a 32-bit unit to address 2 | Writing a 32-bit unit to address 3 | Writing a 32-bit unit to address 4 |
| Address 0          | Transfer from HH                   | _                                  | _                                  | _                                  | _                                  |
| Address 1          | Transfer from HL                   | Transfer from HH                   | _                                  | _                                  | _                                  |
| Address 2          | Transfer from LH                   | Transfer from HL                   | Transfer from HH                   | _                                  | _                                  |
| Address 3          | Transfer from LL                   | Transfer from LH                   | Transfer from HL                   | Transfer from HH                   | _                                  |
| Address 4          | _                                  | Transfer from LL                   | Transfer from LH                   | Transfer from HL                   | Transfer from HH                   |
| Address 5          | _                                  | _                                  | Transfer from LL                   | Transfer from LH                   | Transfer from HL                   |
| Address 6          | _                                  | _                                  | _                                  | Transfer from LL                   | Transfer from LH                   |
| Address 7          | _                                  | _                                  | _                                  | _                                  | Transfer from LL                   |

Table 2.5 16-Bit Read Operations when Little Endian has been Selected

| Operation Address of src | Reading<br>a 16-bit unit<br>from address 0 | Reading<br>a 16-bit unit<br>from address 1 | Reading<br>a 16-bit unit<br>from address 2 | Reading<br>a 16-bit unit<br>from address 3 | Reading<br>a 16-bit unit<br>from address 4 | Reading<br>a 16-bit unit<br>from address 5 | Reading<br>a 16-bit unit<br>from address 6 |
|--------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|
| Address 0                | Transfer to LL                             | _                                          | _                                          | _                                          | _                                          | _                                          | _                                          |
| Address 1                | Transfer to LH                             | Transfer to LL                             | _                                          | _                                          | _                                          | _                                          | _                                          |
| Address 2                | _                                          | Transfer to LH                             | Transfer to LL                             | _                                          | _                                          | _                                          | _                                          |
| Address 3                | _                                          | _                                          | Transfer to LH                             | Transfer to LL                             | _                                          | _                                          | _                                          |
| Address 4                | _                                          | _                                          | _                                          | Transfer to LH                             | Transfer to LL                             | _                                          | _                                          |
| Address 5                | _                                          | _                                          | _                                          | _                                          | Transfer to LH                             | Transfer to LL                             | _                                          |
| Address 6                | _                                          | _                                          | _                                          | _                                          | _                                          | Transfer to LH                             | Transfer to LL                             |
| Address 7                | _                                          | _                                          | _                                          | _                                          | _                                          | _                                          | Transfer to LH                             |

Table 2.6 16-Bit Read Operations when Big Endian has been Selected

| Operation Address of src | Reading        | Reading<br>a 16-bit unit from<br>address 1 | Reading<br>a 16-bit unit from<br>address 2 | Reading<br>a 16-bit unit from<br>address 3 | Reading<br>a 16-bit unit from<br>address 4 | Reading<br>a 16-bit unit from<br>address 5 | Reading<br>a 16-bit unit from<br>address 6 |
|--------------------------|----------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|
| Address 0                | Transfer to LH | _                                          | _                                          | _                                          | _                                          | _                                          | _                                          |
| Address 1                | Transfer to LL | Transfer to LH                             | _                                          | _                                          | _                                          | _                                          | _                                          |
| Address 2                | _              | Transfer to LL                             | Transfer to LH                             | _                                          | _                                          | _                                          | _                                          |
| Address 3                | _              | _                                          | Transfer to LL                             | Transfer to LH                             | _                                          | _                                          | _                                          |
| Address 4                | _              | _                                          | _                                          | Transfer to LL                             | Transfer to LH                             | _                                          | _                                          |
| Address 5                | _              | _                                          | _                                          | _                                          | Transfer to LL                             | Transfer to LH                             | _                                          |
| Address 6                | _              | _                                          | _                                          | _                                          | _                                          | Transfer to LL                             | Transfer to LH                             |
| Address 7                | _              | _                                          | _                                          | _                                          | _                                          | _                                          | Transfer to LL                             |

Table 2.7 16-Bit Write Operations when Little Endian has been Selected

| Operation Address of dest | Writing<br>a 16-bit unit to<br>address 0 | Writing<br>a 16-bit unit to<br>address 1 | Writing<br>a 16-bit unit to<br>address 2 | Writing<br>a 16-bit unit to<br>address 3 | Writing<br>a 16-bit unit to<br>address 4 | Writing<br>a 16-bit unit to<br>address 5 | Writing<br>a 16-bit unit to<br>address 6 |
|---------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|
| Address 0                 | Transfer from LL                         | _                                        | _                                        | _                                        | _                                        | _                                        | _                                        |
| Address 1                 | Transfer from LH                         | Transfer from LL                         | _                                        | _                                        | _                                        | _                                        | _                                        |
| Address 2                 | _                                        | Transfer from LH                         | Transfer from LL                         | _                                        | _                                        | _                                        | _                                        |
| Address 3                 | _                                        | _                                        | Transfer from LH                         | Transfer from LL                         | _                                        | _                                        | _                                        |
| Address 4                 | _                                        | _                                        | _                                        | Transfer from LH                         | Transfer from LL                         | _                                        | _                                        |
| Address 5                 | _                                        | _                                        | _                                        | _                                        | Transfer from LH                         | Transfer from LL                         | _                                        |
| Address 6                 | _                                        | _                                        | _                                        | _                                        | _                                        | Transfer from LH                         | Transfer from LL                         |
| Address 7                 | _                                        | _                                        | _                                        | _                                        | _                                        | _                                        | Transfer from LH                         |

Table 2.8 16-Bit Write Operations when Big Endian has been Selected

| Operation Address of dest | Writing<br>a 16-bit unit to<br>address 0 | Writing<br>a 16-bit unit to<br>address 1 | Writing<br>a 16-bit unit to<br>address 2 | Writing<br>a 16-bit unit to<br>address 3 | Writing<br>a 16-bit unit to<br>address 4 | Writing<br>a 16-bit unit to<br>address 5 | Writing<br>a 16-bit unit to<br>address 6 |
|---------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|------------------------------------------|
| Address 0                 | Transfer from LL                         | _                                        | _                                        |                                          | _                                        | _                                        | _                                        |
| Address 1                 | Transfer from LH                         | Transfer from LL                         | _                                        | _                                        | _                                        | _                                        | _                                        |
| Address 2                 | _                                        | Transfer from LH                         | Transfer from LL                         | _                                        | _                                        | _                                        | _                                        |
| Address 3                 | _                                        | _                                        | Transfer from LH                         | Transfer from LL                         | _                                        | _                                        | _                                        |
| Address 4                 | _                                        | _                                        | _                                        | Transfer from LH                         | Transfer from LL                         | _                                        | _                                        |
| Address 5                 | _                                        | _                                        | _                                        | _                                        | Transfer from LH                         | Transfer from LL                         | _                                        |
| Address 6                 | _                                        | _                                        | _                                        | _                                        | _                                        | Transfer from LH                         | Transfer from LL                         |
| Address 7                 | _                                        | _                                        | _                                        | _                                        | _                                        | _                                        | Transfer from LH                         |

Table 2.9 8-Bit Read Operations when Little Endian has been Selected

| Operation Address of src |                | Reading an 8-bit unit from address 1 | Reading an 8-bit unit from address 2 | Reading an 8-bit unit from address 3 |
|--------------------------|----------------|--------------------------------------|--------------------------------------|--------------------------------------|
| Address 0                | Transfer to LL | _                                    | _                                    | _                                    |
| Address 1                | _              | Transfer to LL                       | _                                    | _                                    |
| Address 2                | _              | _                                    | Transfer to LL                       | _                                    |
| Address 3                | _              | _                                    | _                                    | Transfer to LL                       |

Table 2.10 8-Bit Read Operations when Big Endian has been Selected

| Operation Address of src | Reading an 8-bit unit from address 0 | Reading an 8-bit unit from address 1 | Reading an 8-bit unit from address 2 | Reading an 8-bit unit from address 3 |
|--------------------------|--------------------------------------|--------------------------------------|--------------------------------------|--------------------------------------|
| Address 0                | Transfer to LL                       | _                                    | _                                    | _                                    |
| Address 1                | _                                    | Transfer to LL                       | _                                    | _                                    |
| Address 2                | _                                    | _                                    | Transfer to LL                       | _                                    |
| Address 3                | _                                    | _                                    | _                                    | Transfer to LL                       |

Table 2.11 8-Bit Write Operations when Little Endian has been Selected

| Operation Address of dest | Writing an 8-bit unit to address 0 | Writing an 8-bit unit to address 1 | Writing an 8-bit unit to address 2 | Writing an 8-bit unit to address 3 |
|---------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|
| Address 0                 | Transfer from LL                   | _                                  | _                                  | _                                  |
| Address 1                 | _                                  | Transfer from LL                   | _                                  | _                                  |
| Address 2                 | _                                  | _                                  | Transfer from LL                   | _                                  |
| Address 3                 | _                                  | _                                  | _                                  | Transfer from LL                   |

Table 2.12 8-Bit Write Operations when Big Endian has been Selected

| Operation Address of dest | Writing an 8-bit unit to address 0 | Writing an 8-bit unit to address 1 | Writing an 8-bit unit to address 2 | Writing an 8-bit unit to address 3 |
|---------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|
| Address 0                 | Transfer from LL                   | _                                  | _                                  | _                                  |
| Address 1                 | _                                  | Transfer from LL                   | _                                  | _                                  |
| Address 2                 | _                                  | _                                  | Transfer from LL                   | _                                  |
| Address 3                 | _                                  | _                                  | _                                  | Transfer from LL                   |

### 2.5.2 Access to I/O Registers

The addresses of I/O registers are fixed, and this is regardless of whether the setting is for little endian or big endian. Accordingly, changes to the endian do not affect access to I/O registers. For the arrangements of I/O registers, refer to the descriptions of registers in the relevant sections.

### 2.5.3 Notes on Access to I/O Registers

Ensure that access to I/O registers is in accord with the following rules.

- With I/O registers for which a bus width of 8 bits is indicated, use instructions having operands of the same width (8 bits). That is, access these registers by using instructions with .B as the size specifier (.size), or with .B or .UB as the size-extension specifier (.memex).
- With I/O registers for which a bus width of 16 bits is indicated, use instructions having operands of the same width (16 bits). That is, access these registers by using instructions with .W as the size specifier (.size), or with .W or .UW as the size-extension specifier (.memex).
- With I/O registers for which a bus width of 32 bits is indicated, use instructions having operands of the same width (32 bits). That is, access these registers by using instructions with .L as the size specifier (.size), or with .L size-extension specifier (.memex).

### 2.5.4 Data Arrangement

#### 2.5.4.1 Data Arrangement in Registers

Figure 2.2 shows the relation between the sizes of registers and bit numbers.



Figure 2.2 Data Arrangement in Registers

# 2.5.4.2 Data Arrangement in Memory

Data in memory have three sizes: byte (8-bit), word (16-bit), and longword (32-bit). The data arrangement is selectable as little endian or big endian. Figure 2.3 shows the arrangement of data in memory.



Figure 2.3 Data Arrangement in Memory

#### 2.5.5 Notes on the Allocation of Instruction Codes

The allocation of instruction codes to an external space where the endian differs from that of the chip is prohibited. If the instruction codes are allocated to the external space, they must be allocated to areas where the endian setting is the same as that for the chip.

#### 2.6 Vector Table

There are two types of vector table: fixed and relocatable. Each vector in the vector table consists of 4 bytes and specifies the address where the corresponding exception handling routine starts.

#### 2.6.1 Fixed Vector Table

The fixed vector table is allocated to a fixed address range. The individual vectors for the privileged instruction exception, undefined instruction exception, non-maskable interrupt, and reset are allocated to addresses in the range from FFFFFF80h to FFFFFFFh. Figure 2.4 shows the fixed vector table.



Figure 2.4 Fixed Vector Table

# 2.6.2 Relocatable Vector Table

The address where the relocatable vector table is placed can be adjusted. The table is a 1,024-byte region that contains all vectors for unconditional traps and interrupts and starts at the address (IntBase) specified in the interrupt table register (INTB). Figure 2.5 shows the relocatable vector table.

Each vector in the relocatable vector table has a vector number from 0 to 255. Each of the INT instructions, which act as the sources of unconditional traps, is allocated to the vector that has the same number as is specified as the operand of the instruction itself (from 0 to 255). The BRK instruction is allocated to the vector with number 0. Furthermore, vector numbers (from 0 to 255) are allocated to interrupt requests in a fixed way for each product. For more on interrupt vector numbers, refer to section 14.3.1, Interrupt Vector Table.



Figure 2.5 Relocatable Vector Table

#### 2.7 Operation of Instructions

# 2.7.1 Data Prefetching by the RMPA Instruction and the String-Manipulation Instructions

The RMPA instruction and the string-manipulation instructions except the SSTR instruction (that is, SCMPU, SMOVB, SMOVF, SMOVU, SUNTIL, and SWHILE instructions) may prefetch data from the memory to speed up the read processing. Data is prefetched from the prefetching start position with 3 bytes as the upper limit. The prefetching start positions of each operation are shown below.

- RMPA instruction: The multiplicand address specified by R1, and the multiplier address specified by R2
- SCMPU instruction: The source address specified by R1 for comparison, and the destination address specified by R2 for comparison
- SUNTIL and SWHILE instructions: The destination address specified by R1 for comparison
- SMOVB, SMOVF, and SMOVU instructions: The source address specified by R2 for transfer

#### 2.8 Pipeline

#### 2.8.1 Overview

The RX CPU has five-stage pipeline structure. The RX CPU instruction is converted into one or more micro-operations, which are then executed in pipeline processing. In the pipeline stage, the IF stage is executed in the unit of instructions, while the D and subsequent stages are executed in the unit of micro-operations.

The operation of pipeline and respective stages is described below.

#### (1) IF stage (instruction fetch stage)

In the IF stage, the CPU fetches instructions from the memory. As the RX CPU has four 4-byte instruction queues, it fetches instructions until the instruction queue is full, regardless of the completion of decoding in the D (decoding) stage.

#### (2) D stage (decoding stage)

The CPU decodes instructions (DEC) in the D stage and converts them into micro-operations. The CPU reads the register information (RF) in this stage and executes a bypass process (BYP) if the result of the preceding instruction will be used in a subsequent instruction. The write of operation result to the register (RW) can be executed with the register reference by using the bypass process.

#### (3) E stage (execution stage)

Operations and address calculations (OP) are processed in the E stage.

#### (4) M stage (memory access stage)

Operand memory accesses (OA1, OA2) are processed in the M stage. This stage is used only when the memory is accessed, and is divided into two sub-stages, M1 and M2. The RX CPU enables respective memory accesses for M1 and M2.

- M1 stage (memory-access stage 1)
  - Operand memory access (OA1) is processed.
  - Store operation: The pipeline processing ends when a write request is received via the bus.
  - Load operation: The operation proceeds to the M2 stage when a read request is received via the bus. If a request and load data are received at the same timing (no-wait memory access), the operation proceeds to the WB stage.
- M2 stage (memory-access stage 2)
  - Operand memory access (OA2) is processed. The CPU waits for the load data in the M2 stage. When the load data is received, the operation proceeds to the WB stage.



#### (5) WB stage (write-back stage)

The operation result and the data read from memory are written to the register (RW) in the WB stage. The data read from memory and the other type of data, such as the operation result, can be written to the register in the same clock cycles.

Figure 2.6 shows the pipeline configuration and its operation.



Figure 2.6 Pipeline Configuration and its Operation

#### 2.8.2 Instructions and Pipeline Processing

The operands in the table below indicate the following meaning.

#IMM: Immediate flag: bit, flag

Rs, Rs2, Rd, Rd2, Ri, Rb: General-purpose register

CR: Control register dsp: displacement pcdsp: displacement

#### 2.8.2.1 Instructions Converted into Single Micro-Operation and Pipeline Processing

The table below lists the instructions that are converted into a single micro-operation. The number of cycles in the table indicates the number of cycles during no-wait memory access.

Table 2.13 Instructions that are Converted into a Single Micro-Operation

| Instruction                                                                                                                 | Mnemonic (indicates the common operation when the size is omitted)                                                                                                                                                                                                                                                                                                                                                      | Reference<br>Figure | Number of<br>Cycles                       |
|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------------------------------|
| Arithmetic/logic instructions<br>(register-register, immediate-register)<br>Except EMUL, EMULU, RMPA, DIV,<br>DIVU and SATR | <ul> <li>{ABS, NEG, NOT} "Rd"/"Rs, Rd"</li> <li>{ADC, MAX, MIN, ROTL, ROTR, XOR} "#IMM, Rd"/"Rs, Rd"</li> <li>ADD "#IMM, Rd"/"Rs, Rd"/"#IMM, Rs, Rd"/"Rs, Rs2, Rd"</li> <li>{AND, MUL, OR, SUB} "#IMM, Rd"/"Rs, Rd"/"Rs, Rs2, Rd"</li> <li>{CMP, TST} "#IMM, Rs"/"Rs, Rs2"</li> <li>NOP</li> <li>{ROLC, RORC, SAT} "Rd"</li> <li>SBB "Rs, Rd"</li> <li>{SHAR, SHLL, SHLR} "#IMM, Rd"/"Rs, Rd"/"#IMM, Rs, Rd"</li> </ul> | Figure 2.7          | 1                                         |
| Arithmetic/logic instructions (division)                                                                                    | DIV "#IMM, Rd"/"Rs, Rd"                                                                                                                                                                                                                                                                                                                                                                                                 | Figure 2.7          | 3 to 20*1                                 |
|                                                                                                                             | DIVU "#IMM, Rd"/"Rs, Rd"                                                                                                                                                                                                                                                                                                                                                                                                | Figure 2.7          | 2 to 18*1                                 |
| Data transfer instructions (register-register, immediate-register)                                                          | <ul> <li>MOV "#IMM, Rd"/"Rs, Rd"</li> <li>{MOVU, REVL, REVW} "Rs, Rd"</li> <li>SCCnd "Rd"</li> <li>{STNZ, STZ} "#IMM, Rd"</li> </ul>                                                                                                                                                                                                                                                                                    | Figure 2.7          | 1                                         |
| Transfer instructions (load operation)                                                                                      | <ul> <li>{MOV, MOVU} "[Rs], Rd"/"dsp[Rs], Rd"/"[Rs+], Rd"/"[-Rs], Rd"/"[Ri, Rb], Rd"</li> <li>POP "Rd"</li> </ul>                                                                                                                                                                                                                                                                                                       | Figure 2.8          | Throughput: 1<br>Latency: 2*2             |
| Transfer instructions (store operation)                                                                                     | <ul> <li>MOV "Rs, [Rd]"/"Rs, dsp[Rd]"/"Rs, [Rd+]"/"Rs, [-Rd]"/"Rs, [Ri, Rb]"/"#IMM, dsp[Rd]"/"#IMM, [Rd]"</li> <li>PUSH "Rs"</li> <li>PUSHC "CR"</li> <li>SCCnd "[Rd]"/"dsp[Rd]"</li> </ul>                                                                                                                                                                                                                             | Figure 2.9          | 1                                         |
| Bit manipulation instructions (register)                                                                                    | <ul> <li>{BCLR, BNOT, BSET} "#IMM, Rd"/"Rs, Rd"</li> <li>BMCnd "#IMM, Rd"</li> <li>BTST "#IMM, Rs"/"Rs, Rs2"</li> </ul>                                                                                                                                                                                                                                                                                                 | Figure 2.7          | 1                                         |
| Branch instructions                                                                                                         | BCnd "pcdsp"  {BRA, BSR} "pcdsp"/"Rs"  {JMP, JSR} "Rs"                                                                                                                                                                                                                                                                                                                                                                  | Figure 2.17         | Branch taken: 3<br>Branch not<br>taken: 1 |
| System manipulation instructions                                                                                            | <ul> <li>{CLRPSW, SETPSW} "flag"</li> <li>MVTC "#IMM, CR"/"Rs, CR"</li> <li>MVFC "CR, Rd"</li> <li>MVTIPL"#IMM"</li> </ul>                                                                                                                                                                                                                                                                                              | _                   | 1                                         |
| DSP instructions                                                                                                            | • {MACHI, MACLO, MULHI, MULLO} "Rs, Rs2" • {MVFACHI, MVFACMI} "Rd" • {MVTACHI, MVTACLO} "Rs" • RACW"#IMM"                                                                                                                                                                                                                                                                                                               | Figure 2.7          | 1                                         |

Note 1. The number of cycles for the dividing instruction varies according to the divisor and dividend.

Note 2. For the number of cycles for throughput and latency, refer to section 2.8.3, Calculation of the Instruction Processing Time.

Figure 2.7 to Figure 2.9 show the operation of instructions that are converted into a basic single micro-operation.



Figure 2.7 Operation for Register-Register, Immediate-Register



Figure 2.8 Load Operation



Figure 2.9 Store Operation

# 2.8.2.2 Instructions Converted into Multiple Micro-Operations and Pipeline Processing

The table below lists the instructions that are converted into multiple micro-operations. The number of cycles in the table indicates the number of cycles during no-wait memory access.

Table 2.14 Instructions that are Converted into Multiple Micro-Operations (1/2)

| Instruction                                                                                                    | Mnemonic (indicates the common operation when the size is omitted)                                                                                                                                             | Reference<br>Figure | Number of Cycles                                                        |
|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-------------------------------------------------------------------------|
| Arithmetic/logic instructions (memory source operand)                                                          | <ul> <li>{ADC, ADD, AND, MAX, MIN, MUL, OR, SBB, SUB, XOR} "[Rs], Rd"/"dsp[Rs], Rd"</li> <li>{CMP, TST} "[Rs], Rs2"/"dsp[Rs], Rs2"</li> </ul>                                                                  | Figure 2.10         | 3                                                                       |
| Arithmetic/logic instructions                                                                                  | • DIV "[Rs], Rd / dsp[Rs], Rd"                                                                                                                                                                                 | _                   | 5 to 22                                                                 |
| (division)                                                                                                     | DIVU"[Rs], Rd / dsp[Rs], Rd"                                                                                                                                                                                   | _                   | 4 to 20                                                                 |
| Arithmetic/logic instruction<br>(multiplier: 32 × 32 → 64 bits)<br>(register-register, register-<br>immediate) | • {EMUL, EMULU} "#IMM, Rd"/"Rs, Rd"                                                                                                                                                                            | Figure 2.12         | 2                                                                       |
| Arithmetic/logic instruction<br>(multiplier: 32 × 32 → 64 bits)<br>(memory source operand)                     | • {EMUL, EMULU} "[Rs], Rd"/"dsp[Rs], Rd"                                                                                                                                                                       | _                   | 4                                                                       |
| Arithmetic/logic instructions<br>(multiply-and-accumulate<br>operation)                                        | • RMPA.B                                                                                                                                                                                                       | _                   | 6+7×floor(n/4)+4×(n%4)<br>n: Number of processing<br>bytes*1            |
|                                                                                                                | • RMPA.W                                                                                                                                                                                                       | _                   | 6+5×floor(n/2)+4×(n%2)<br>n: Number of processing<br>words*1            |
|                                                                                                                | • RMPA.L                                                                                                                                                                                                       | _                   | 6+4n<br>n: Number of processing<br>longwords*1                          |
| Arithmetic/logic instruction (64-bit<br>signed saturation processing for<br>the RMPA instruction)              | • SATR                                                                                                                                                                                                         | _                   | 3                                                                       |
| Data transfer instructions (memory-memory transfer)                                                            | <ul> <li>MOV "[Rs], [Rd]"/"dsp[Rs], [Rd]"/"[Rs], dsp[Rd]"/ "dsp[Rs], dsp[Rd]"</li> <li>PUSH "[Rs]"/"dsp[Rs]"</li> </ul>                                                                                        | Figure 2.11         | 3                                                                       |
| Bit manipulation instructions (memory source operand)                                                          | <ul> <li>{BCLR, BNOT, BSET} "#IMM, [Rd]"/"#IMM, dsp[Rd]"/ "Rs, [Rd]"/"Rs, dsp[Rd]"</li> <li>BMCnd "#IMM, [Rd]"/"#IMM, dsp[Rd]"</li> <li>BTST "#IMM, [Rs]"/"#IMM, dsp[Rs]"/"Rs, [Rs2]"/"Rs, dsp[Rs2]</li> </ul> | Figure 2.11         | 3                                                                       |
| Transfer instruction<br>(load operation)                                                                       | • POPC "CR"                                                                                                                                                                                                    | _                   | Throughput: 3<br>Latency: 4*2                                           |
| Transfer instruction (save operation of multiple registers)                                                    | PUSHM "Rs-Rs2"                                                                                                                                                                                                 | _                   | n<br>n: Number of registers*3                                           |
| Transfer instruction (restore operation of multiple registers)                                                 | • POPM "Rs-Rs2"                                                                                                                                                                                                | _                   | Throughput: n<br>Latency: n+1<br>n: Number of<br>registers*2,*4         |
| Transfer instruction<br>(register-register)                                                                    | • XCHG "Rs, Rd"                                                                                                                                                                                                | Figure 2.13         | 2                                                                       |
| Transfer instruction<br>(memory-register)                                                                      | XCHG "[Rs], Rd"/"dsp[Rs], Rd"                                                                                                                                                                                  | Figure 2.14         | 2                                                                       |
| Branch instructions                                                                                            | • RTS                                                                                                                                                                                                          | _                   | 5                                                                       |
|                                                                                                                | RTSD "#IMM"                                                                                                                                                                                                    | _                   | 5                                                                       |
|                                                                                                                | • RTSD "#IMM, Rd-Rd2"                                                                                                                                                                                          | _                   | Throughput: n<5?5:1+n<br>Latency: n<4?5:2+n<br>n: Number of registers*2 |

Table 2.14 Instructions that are Converted into Multiple Micro-Operations (2/2)

| Instruction                        | Mnemonic (indicates the common operation when the size is omitted) | Reference<br>Figure | Number of Cycles                                                            |
|------------------------------------|--------------------------------------------------------------------|---------------------|-----------------------------------------------------------------------------|
| String manipulation instructions*5 | ·                                                                  | _                   | 2+4×floor(n/4)+4×(n%4)<br>n: Number of comparison<br>bytes*1                |
|                                    | • SMOVB                                                            | _                   | n>3?<br>6+3×floor(n/4)+3×(n%4):<br>2+3n<br>n: Number of transfer<br>bytes*1 |
|                                    | • SMOVF, SMOVU                                                     | _                   | 2+3×floor(n/4)+3×(n%4)<br>n: Number of transfer<br>bytes*1                  |
|                                    | • SSTR.B                                                           | _                   | 2+floor(n/4)+n%4<br>n: Number of transfer<br>bytes*1                        |
|                                    | • SSTR.W                                                           | _                   | 2+floor(n/2)+n%2<br>n: Number of transfer<br>words*1                        |
|                                    | • SSTR.L                                                           | _                   | 2+n<br>n: Number of transfer<br>longwords                                   |
|                                    | • SUNTIL.B, SWHILE.B                                               | _                   | 3+3×floor(n/4)+3×(n%4)<br>n: Number of comparison<br>bytes*1                |
|                                    | • SUNTIL.W, SWHILE.W                                               | _                   | 3+3×floor(n/2)+3×(n%2)<br>n: Number of comparison<br>words*1                |
|                                    | • SUNTIL.L, SWHILE.L                                               | _                   | 3+3×n<br>n: Number of comparison<br>longwords                               |
| System manipulation instructions   | • RTE                                                              | _                   | 6                                                                           |
|                                    | • RTFI                                                             | _                   | 3                                                                           |

<sup>?:</sup> Conditional operator

Note 1. floor(x): Max. integer that is smaller than x

Note 2. For the number of cycles for throughput and latency, refer to section 2.8.3, Calculation of the Instruction Processing Time.

Note 3. The PUSHM instruction is converted into multiple store operations. The pipeline processing is the same as the one for the store operations of the MOV instruction, where the operation is repeated for the number of specified registers.

Note 4. The POPM instruction is converted into multiple load operations. The pipeline processing is the same as the one for the load operations of the MOV instruction, where the operation is repeated for the number of specified registers.

Note 5. Each of the SCMPU, SMOVU, SWHILE, and SUNTIL instructions ends the execution regardless of the specified cycles, if the end condition is satisfied during execution.

Figure 2.10 to Figure 2.14 show the operation of instructions that are converted into basic multiple micro-operations. Note: mop: Micro-operation, stall: Pipeline stall



Figure 2.10 Arithmetic/Logic Instruction (Memory Source Operand)



Figure 2.11 MOV Instruction (Memory-Memory), Bit Manipulation Instruction (Memory Source Operand)



Figure 2.12 EMUL, EMULU Instructions (Register- Register, Register-Immediate)



Figure 2.13 XCHG Instruction (Registers)



Figure 2.14 XCHG Instruction (Memory Source Operand)

## 2.8.2.3 Pipeline Basic Operation

In the ideal pipeline processing, each stage is executed in one cycle, though all instructions may not be pipelined in due to the processing in each stage and the branch execution.

The CPU controls the pipeline stage with the IF stage in the unit of instructions, while the D and subsequent stages in the unit of micro-operations.

The figures below show the pipeline processing of typical cases.

Note: mop: Micro-operation, stall: Pipeline stall

#### (1) Pipeline Flow with Stalls



Figure 2.15 When an Instruction which Requires Multiple Cycles is Executed in the E Stage



Figure 2.16 When an Instruction which Requires more than One Cycle for its Operand Access is Executed



Figure 2.17 When a Branch Instruction is Executed (an Unconditional Branch Instruction is Executed or the Condition is Satisfied for a Conditional Branch Instruction)



Figure 2.18 When the Subsequent Instruction Uses an Operand Read from the Memory

#### (2) Pipeline Flow with no Stall

#### (a) Bypass process

Even when the result of the preceding instruction will be used in a subsequent instruction, the operation processing between registers is pipelined in by the bypass process.



Figure 2.19 Bypass Process

#### (b) When WB stages for the memory load and for the operation are overlapped

Even when the WB stages for the memory load and for the operation are overlapped, the operation processing is pipelined in, because the load data and the operation result can be written to the register at the same timing.



Figure 2.20 When WB Stages for the Memory Load and for the Operation are Overlapped

#### (c) When subsequent instruction writes to the same register before the end of memory load

Even when the subsequent instruction writes to the same register before the end of memory load, the operation processing is pipelined in, because the WB stage for the memory load is canceled.



Figure 2.21 When Subsequent Instruction Writes to the Same Register before the End of Memory Load

#### (d) When the load data is not used by the subsequent instruction

When the load data is not used by the subsequent instruction, the subsequent operations are in fact executed earlier and the operation processing ends (out-of-order completion).



Figure 2.22 When Load Data is not Used by the Subsequent Instruction

### 2.8.3 Calculation of the Instruction Processing Time

Though the instruction processing time of the CPU varies according to the pipeline processing, the approximate time can be calculated in the following methods.

- Count the number of cycles (see Table 2.13 and Table 2.14)
- When the load data is used by the subsequent instruction, the number of cycles described as "latency" is counted as the number of cycles for the memory load instruction. For the cycles other than the memory load instruction, the number of cycles described as "throughput" is counted.
- If the instruction fetch stall is generated, the number of cycles increments.
- Depending on the system configuration, multiple cycles are required for the memory access.

#### 2.8.4 Numbers of Cycles for Response to Interrupts

Table 2.15 lists numbers of cycles taken by processing for response to interrupts.

Table 2.15 Numbers of Cycles for Response to Interrupts

| Type of Interrupt Request/Details of Processing                                                                                                                                                                       | Fast Interrupt                                                | Other Interrupts                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|------------------------------------|
| ICU<br>Judgment of priority order                                                                                                                                                                                     | 2 cycles                                                      |                                    |
| CPU Number of cycles from notification to acceptance of the interrupt request                                                                                                                                         | N cycles<br>(varies with the instruction being execureceived) | uted at the time the interrupt was |
| CPU Pre-processing by hardware Saving the current PC and PSW values in RAM (or in control registers in the case of the fast interrupt) Reading of the vector Branching to the start of the exception handling routine | 4 cycles                                                      | 6 cycles                           |

Times calculated from the values in Table 2.15 will be applicable when access to memory from the CPU is processed with no waiting. The ROM and RAM in products of this MCU allow such access. Numbers of cycles for response to interrupts can be minimized by placing program code (and vectors) in ROM and the stack in RAM. Furthermore, place the addresses where the exception handling routine start on 8-byte boundaries.

For information on the number of cycles from notification to acceptance of the interrupt request, indicated by N in the table above, see Table 2.13, Instructions that are Converted into a Single Micro-Operation, and Table 2.14, Instructions that are Converted into Multiple Micro-Operations.

The timing of interrupt acceptance depends on the state of the pipelines. For more information on this, refer to section 13.3.1, Acceptance Timing and Saved PC Value.

# 3. Operating Modes

# 3.1 Operating Mode Types and Selection

Operating modes are selected by the pin level when a reset is released.

Table 3.1 shows the relationship between levels on the mode setting pins (MD) on release from the reset state and the operating mode selected at that time. For details on each of the operating modes, refer to section 3.3, Details of Operating Modes.

Table 3.1 Selection of Operating Modes by the Mode Setting Pin

| Mode Pin | ——— Operating Mode |  |
|----------|--------------------|--|
| MD *1    | Operating wode     |  |
| Low      | Boot mode (SCI)    |  |
| High     | Single-chip mode   |  |

Note 1. Do not change the level on the MD pin while the MCU is operating.

The endian is selectable in single-chip mode. Endian is set by the MDE.MDE[2:0] bits in the option-setting memory. For the correspondence between the setting and endian, see Table 3.2.

Table 3.2 Endian Setting in Single-Chip Mode

| MDE.MDE[2:0] Bits | Endian        |
|-------------------|---------------|
| 000b              | Big endian    |
| 111b              | Little endian |

# 3.2 Register Descriptions

# 3.2.1 Mode Monitor Register (MDMONR)

Address(es): 0008 0000h



Note 1. Depends on the setting of the mode pin (MD). When the MD pin is low, the bit value is 0; otherwise, the bit value is 1.

| Bit       | Symbol | Bit Name           | Description                                     | R/W |
|-----------|--------|--------------------|-------------------------------------------------|-----|
| b0        | MD     | MD Pin Status Flag | 0: The MD pin is low.<br>1: The MD pin is high. | R   |
| b7 to b1  | _      | Reserved           | These bits are read as 0.                       | R   |
| b8        | _      | Reserved           | The read value is undefined.                    | R   |
| b15 to b9 | _      | Reserved           | These bits are read as 0.                       | R   |

# 3.2.2 System Control Register 1 (SYSCR1)

Address(es): 0008 0008h



| Bit      | Symbol | Bit Name   | Description                                            | R/W |
|----------|--------|------------|--------------------------------------------------------|-----|
| b0       | RAME   | RAM Enable | 0: The RAM is disabled.<br>1: The RAM is enabled.      | R/W |
| b15 to b | 1 —    | Reserved   | These bits are read as 0. The write value should be 0. | R/W |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

#### **RAME Bit (RAM Enable)**

The RAME bit enables or disables the RAM.

A 0 should not be written to this bit during access to the RAM. When accessing the RAM immediately after changing the RAME bit from 0 (RAM disabled) to 1 (RAM enabled), make sure that the RAME bit is 1 before the access.

Even when the RAME bit is set to 0, the RAM retains its value. To retain the value in the RAM, keep the specified RAM standby voltage ( $V_{RAM}$ ). For details, refer to section 32, Electrical Characteristics.

#### 3.3 Details of Operating Modes

#### 3.3.1 Single-Chip Mode

In this mode, all I/O ports can be used as general input/output ports, peripheral function input/output, or interrupt input pins.

The chip starts up in single-chip mode if the high level is on the MD pin on release from the reset state.

#### 3.3.2 Boot Mode

In this mode, the on-chip flash memory modifying program (boot program) stored in a dedicated area within the MCU operates. The on-chip flash memory (ROM) can be modified from outside the MCU by using a universal asynchronous receiver/transmitter (SCI1). For details, refer to section 31, Flash Memory.

The chip starts up in boot mode if the low level is on the MD pin on release from the reset state.

#### 3.3.2.1 Boot Mode (SCI)

When a reset is released while the MD pin is low, boot mode (SCI) is selected. For details on boot mode (SCI), refer to section 31.7.1, Boot Mode (SCI).

#### 3.4 Transitions of Operating Modes

#### 3.4.1 MD Pin Levels and Operating Mode Transitions

Figure 3.1 shows operating mode transitions according to the setting of the MD pin.



Figure 3.1 MD Pin Levels and Operating Modes

RX110 Group 4. Address Space

# 4. Address Space

# 4.1 Address Space

This MCU has a 4-Gbyte address space, consisting of the range of addresses from 0000 0000h to FFFF FFFFh. That is, linear access to an address space of up to 4 Gbytes is possible, and this contains program area.

Figure 4.1 shows the memory map.



RX110 Group 4. Address Space



Note 1. The address space in boot mode is the same as the address space in single-chip mode.

Note 2. The capacity of ROM/RAM differs depending on the products.

| ROM (byte        | ROM (bytes)              |          | s)                       |
|------------------|--------------------------|----------|--------------------------|
| Capacity Address |                          | Capacity | Address                  |
| 128 K            | FFFE 0000h to FFFF FFFFh | 16 K     | 0000 0000h to 0000 3FFFh |
| 96 K             | FFFE 8000h to FFFF FFFFh |          |                          |
| 64 K             | FFFF 0000h to FFFF FFFFh | 10 K     | 0000 0000h to 0000 27FFh |
| 32 K             | FFFF 8000h to FFFF FFFFh |          |                          |
| 16 K             | FFFF C000h to FFFF FFFFh | 8 K      | 0000 0000h to 0000 1FFFh |
| 8 K              | FFFF E000h to FFFF FFFFh |          |                          |

Note:See Table 1.3, List of Products, for the product type name.

Note 3. Reserved areas should not be accessed.

Figure 4.1 Memory Map

# I/O Registers

This section provides information on the on-chip I/O register addresses and bit configuration. The information is given as shown below. Notes on writing to I/O registers are also given below.

#### (1) I/O register addresses (address order)

- Registers are listed from the lower allocation addresses.
- Registers are classified according to module symbols.
- Numbers of cycles for access indicate numbers of cycles of the given base clock.
- Among the internal I/O register area, addresses not listed in the list of registers are reserved. Reserved addresses
  must not be accessed. Do not access these addresses; otherwise, the operation when accessing these bits and
  subsequent operations cannot be guaranteed.

#### (2) Notes on writing to I/O registers

While writing to an I/O register, the CPU starts executing subsequent instructions before the I/O register write access is completed. This may cause the subsequent instructions to be executed before the write value is reflected in the operation. The examples below show how subsequent instructions must be executed after a write access to an I/O register is completed.

#### [Examples of cases requiring special care]

- The subsequent instruction must be executed while an interrupt request is disabled with the IENj bit in IERn of the ICU (interrupt request enable bit) set to 0.
- A WAIT instruction is executed immediately after the preprocessing for causing a transition to the low power consumption state.

In the above cases, after writing to an I/O register, wait until the write operation is completed using the following procedure and then execute the subsequent instruction.

- (a) Write to an I/O register.
- (b) Read the value in the I/O register and write it to a general register.
- (c) Execute the operation using the value read.
- (d) Execute the subsequent instruction.

#### Example of instructions

• Byte-size I/O registers

MOV.L #SFR\_ADDR, R1 MOV.B #SFR\_DATA, [R1] CMP [R1].UB, R1 ;; Next process

Word-size I/O registers

MOV.L #SFR\_ADDR, R1 MOV.W #SFR\_DATA, [R1] CMP [R1].W, R1 ;; Next process

• Longword-size I/O registers

MOV.L #SFR\_ADDR, R1 MOV.L #SFR\_DATA, [R1] CMP [R1].L, R1 ;; Next process

When executing an instruction after writing to multiple registers, only read the last I/O register written to and execute the instruction using that value; it is not necessary to execute the instruction using the values written to all the registers.

#### (3) Number of cycles necessary for accessing I/O registers

See Table 5.1 for details on the number of clock cycles necessary for accessing I/O registers. The number of access cycles to I/O registers is obtained by following equation.\*1

Number of access cycles to I/O registers = Number of bus cycles for internal main bus 1 +

Number of divided clock synchronization cycles +

Number of bus cycles for internal peripheral buses 1, 2, and 4 to 6

The number of bus cycles of internal peripheral buses 1, 2, and 4 to 6 differs according to the register to be accessed. When peripheral functions connected to internal peripheral buses 2, and 4 to 6 or registers for the external bus control unit (except for bus error related registers) are accessed, the number of divided clock synchronization cycles is added. The number of divided clock synchronization cycles differs depending on the frequency ratio between ICLK and PCLK (or FCLK) or bus access timing.

In the peripheral function unit, when the frequency ratio of ICLK is equal to or greater than that of PCLK (or FCLK), the sum of the number of bus cycles for internal main bus 1 and the number of the divided clock synchronization cycles will be one cycle of PCLK (or FCLK) at a maximum. Therefore, one PCLK (or FCLK) has been added to the number of access cycles shown in Table 5.1.

When the frequency ratio of ICLK is lower than that of PCLK (or FCLK), the subsequent bus access is started from the ICLK cycle following the completion of the access to the peripheral functions. Therefore, the access cycles are described on an ICLK basis.

Note 1. This applies to the number of cycles when the access from the CPU does not conflict with the bus access from the different bus master (DTC).

#### (4) Notes on sleep mode and mode transitions

During sleep mode or mode transitions, do not write to the system control related registers (indicated by 'SYSTEM' in the Module Symbol column in Table 5.1, List of I/O Registers (Address Order)).

# 5.1 I/O Register Addresses (Address Order)

Table 5.1 List of I/O Registers (Address Order) (1/13)

| Address    | Module<br>Symbol | Register Name                                       | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|------------|------------------|-----------------------------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 0000h | SYSTEM           | Mode Monitor Register                               | MDMONR             | 16                | 16             | 3 ICLK                     | section 3.           |
| 0008 0008h | SYSTEM           | System Control Register 1                           | SYSCR1             | 16                | 16             | 3 ICLK                     | section 3.           |
| 0008 000Ch | SYSTEM           | Standby Control Register                            | SBYCR              | 16                | 16             | 3 ICLK                     | section 11.          |
| 0008 0010h | SYSTEM           | Module Stop Control Register A                      | MSTPCRA            | 32                | 32             | 3 ICLK                     | section 11.          |
| 0008 0014h | SYSTEM           | Module Stop Control Register B                      | MSTPCRB            | 32                | 32             | 3 ICLK                     | section 11.          |
| 0008 0018h | SYSTEM           | Module Stop Control Register C                      | MSTPCRC            | 32                | 32             | 3 ICLK                     | section 11.          |
| 0008 0020h | SYSTEM           | System Clock Control Register                       | SCKCR              | 32                | 32             | 3 ICLK                     | section 9.           |
| 0008 0026h | SYSTEM           | System Clock Control Register 3                     | SCKCR3             | 16                | 16             | 3 ICLK                     | section 9.           |
| 0008 0032h | SYSTEM           | Main Clock Oscillator Control Register              | MOSCCR             | 8                 | 8              | 3 ICLK                     | section 9.           |
| 0008 0033h | SYSTEM           | Sub-Clock Oscillator Control Register               | SOSCCR             | 8                 | 8              | 3 ICLK                     | section 9.           |
| 0008 0034h | SYSTEM           | Low-Speed On-Chip Oscillator Control Register       | LOCOCR             | 8                 | 8              | 3 ICLK                     | section 9.           |
| 0008 0035h | SYSTEM           | IWDT-Dedicated On-Chip Oscillator Control Register  | ILOCOCR            | 8                 | 8              | 3 ICLK                     | section 9.           |
| 0008 0036h | SYSTEM           | High-Speed On-Chip Oscillator Control Register      | HOCOCR             | 8                 | 8              | 3 ICLK                     | section 9.           |
| 0008 003Ch | SYSTEM           | Oscillation Stabilization Flag Register             | OSCOVFSR           | 8                 | 8              | 3 ICLK                     | section 9.           |
| 0008 003Eh | SYSTEM           | CLKOUT Output Control Register                      | CKOCR              | 16                | 16             | 3 ICLK                     | section 9.           |
| 0008 0040h | SYSTEM           | Oscillation Stop Detection Control Register         | OSTDCR             | 8                 | 8              | 3 ICLK                     | section 9.           |
| 0008 0041h | SYSTEM           | Oscillation Stop Detection Status Register          | OSTDSR             | 8                 | 8              | 3 ICLK                     | section 9.           |
| 0008 00A0h | SYSTEM           | Operating Power Control Register                    | OPCCR              | 8                 | 8              | 3 ICLK                     | section 11.          |
| 0008 00A1h | SYSTEM           | Sleep Mode Return Clock Source Switching Register   | RSTCKCR            | 8                 | 8              | 3 ICLK                     | section 11.          |
| 0008 00A2h | SYSTEM           | Main Clock Oscillator Wait Control Register         | MOSCWTCR           | 8                 | 8              | 3 ICLK                     | section 9.           |
| 0008 00A5h | SYSTEM           | High-Speed On-Chip Oscillator Wait Control Register | HOCOWTCR           | 8                 | 8              | 3 ICLK                     | section 9.           |
| 0008 00AAh | SYSTEM           | Sub Operating Power Control Register                | SOPCCR             | 8                 | 8              | 3 ICLK                     | section 11.          |
| 0008 00C0h | SYSTEM           | Reset Status Register 2                             | RSTSR2             | 8                 | 8              | 3 ICLK                     | section 6.           |
| 0008 00C2h | SYSTEM           | Software Reset Register                             | SWRR               | 16                | 16             | 3 ICLK                     | section 6.           |
| 0008 00E0h | SYSTEM           | Voltage Monitoring 1 Circuit Control Register 1     | LVD1CR1            | 8                 | 8              | 3 ICLK                     | section 8.           |
| 0008 00E1h | SYSTEM           | Voltage Monitoring 1 Circuit Status Register        | LVD1SR             | 8                 | 8              | 3 ICLK                     | section 8.           |
| 0008 00E2h | SYSTEM           | Voltage Monitoring 2 Circuit Control Register 1     | LVD2CR1            | 8                 | 8              | 3 ICLK                     | section 8.           |
| 0008 00E3h | SYSTEM           | Voltage Monitoring 2 Circuit Status Register        | LVD2SR             | 8                 | 8              | 3 ICLK                     | section 8.           |
| 0008 03FEh | SYSTEM           | Protect Register                                    | PRCR               | 16                | 16             | 3 ICLK                     | section 12.          |
| 0008 1300h | BSC              | Bus Error Status Clear Register                     | BERCLR             | 8                 | 8              | 2 ICLK                     | section 15.          |
| 0008 1304h | BSC              | Bus Error Monitoring Enable Register                | BEREN              | 8                 | 8              | 2 ICLK                     | section 15.          |
| 0008 1308h | BSC              | Bus Error Status Register 1                         | BERSR1             | 8                 | 8              | 2 ICLK                     | section 15.          |
| 0008 130Ah | BSC              | Bus Error Status Register 2                         | BERSR2             | 16                | 16             | 2 ICLK                     | section 15.          |
| 0008 1310h | BSC              | Bus Priority Control Register                       | BUSPRI             | 16                | 16             | 2 ICLK                     | section 15.          |
| 0008 2400h | DTC              | DTC Control Register                                | DTCCR              | 8                 | 8              | 2 ICLK                     | section 16.          |
| 0008 2404h | DTC              | DTC Vector Base Register                            | DTCVBR             | 32                | 32             | 2 ICLK                     | section 16.          |
| 0008 2408h | DTC              | DTC Address Mode Register                           | DTCADMOD           | 8                 | 8              | 2 ICLK                     | section 16.          |
| 0008 240Ch | DTC              | DTC Module Start Register                           | DTCST              | 8                 | 8              | 2 ICLK                     | section 16.          |
| 0008 240Eh | DTC              | DTC Status Register                                 | DTCSTS             | 16                | 16             | 2 ICLK                     | section 16.          |
| 0008 7010h | ICU              | Interrupt Request Register 016                      | IR016              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 701Bh | ICU              | Interrupt Request Register 027                      | IR027              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 701Ch | ICU              | Interrupt Request Register 028                      | IR028              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 701Dh | ICU              | Interrupt Request Register 029                      | IR029              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7020h | ICU              | Interrupt Request Register 032                      | IR032              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7021h | ICU              | Interrupt Request Register 033                      | IR033              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7022h | ICU              | Interrupt Request Register 034                      | IR034              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7024h | ICU              | Interrupt Request Register 036                      | IR036              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7025h | ICU              | Interrupt Request Register 037                      | IR037              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7026h | ICU              | Interrupt Request Register 038                      | IR038              | 8                 | 8              | 2 ICLK                     | section 14.          |
|            |                  |                                                     |                    |                   |                |                            |                      |

Table 5.1 List of I/O Registers (Address Order) (2/13)

| Address    | Module<br>Symbol | Register Name                  | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|------------|------------------|--------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 702Dh | ICU              | Interrupt Request Register 045 | IR045              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 702Eh | ICU              | Interrupt Request Register 046 | IR046              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 702Fh | ICU              | Interrupt Request Register 047 | IR047              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7039h | ICU              | Interrupt Request Register 057 | IR057              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 703Fh | ICU              | Interrupt Request Register 063 | IR063              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7040h | ICU              | Interrupt Request Register 064 | IR064              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7041h | ICU              | Interrupt Request Register 065 | IR065              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7042h | ICU              | Interrupt Request Register 066 | IR066              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7043h | ICU              | Interrupt Request Register 067 | IR067              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7044h | ICU              | Interrupt Request Register 068 | IR068              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7045h | ICU              | Interrupt Request Register 069 | IR069              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7046h | ICU              | Interrupt Request Register 070 | IR070              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7047h | ICU              | Interrupt Request Register 071 | IR071              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7058h | ICU              | Interrupt Request Register 088 | IR088              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7059h | ICU              | Interrupt Request Register 089 | IR089              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 705Ah | ICU              | Interrupt Request Register 090 | IR090              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 705Ch | ICU              | Interrupt Request Register 092 | IR092              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 705Dh | ICU              | Interrupt Request Register 093 | IR093              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7066h | ICU              | Interrupt Request Register 102 | IR102              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7067h | ICU              | Interrupt Request Register 103 | IR103              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 706Ah | ICU              | Interrupt Request Register 106 | IR106              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7072h | ICU              | Interrupt Request Register 114 | IR114              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7073h | ICU              | Interrupt Request Register 115 | IR115              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7074h | ICU              | Interrupt Request Register 116 | IR116              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7075h | ICU              | Interrupt Request Register 117 | IR117              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7076h | ICU              | Interrupt Request Register 118 | IR118              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7077h | ICU              | Interrupt Request Register 119 | IR119              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7078h | ICU              | Interrupt Request Register 120 | IR120              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7079h | ICU              | Interrupt Request Register 121 | IR121              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 707Ah | ICU              | Interrupt Request Register 122 | IR122              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 707Bh | ICU              | Interrupt Request Register 123 | IR123              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 707Ch | ICU              | Interrupt Request Register 124 | IR124              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 707Dh | ICU              | Interrupt Request Register 125 | IR125              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 707Eh | ICU              | Interrupt Request Register 126 | IR126              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 707Fh | ICU              | Interrupt Request Register 127 | IR127              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7080h | ICU              | Interrupt Request Register 128 | IR128              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7081h | ICU              | Interrupt Request Register 129 | IR129              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7082h | ICU              | Interrupt Request Register 130 | IR130              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7083h | ICU              | Interrupt Request Register 131 | IR131              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7084h | ICU              | Interrupt Request Register 132 | IR132              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7085h | ICU              | Interrupt Request Register 133 | IR133              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7086h | ICU              | Interrupt Request Register 134 | IR134              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7087h |                  |                                |                    |                   |                |                            |                      |
|            | ICU              | Interrupt Request Register 135 | IR135              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7088h | ICU              | Interrupt Request Register 136 | IR136              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7089h | ICU              | Interrupt Request Register 137 | IR137              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 708Ah | ICU              | Interrupt Request Register 138 | IR138              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 708Bh | ICU              | Interrupt Request Register 139 | IR139              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 708Ch | ICU              | Interrupt Request Register 140 | IR140              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 708Dh | ICU              | Interrupt Request Register 141 | IR141              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70AAh | ICU              | Interrupt Request Register 170 | IR170              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70ABh | ICU              | Interrupt Request Register 171 | IR171              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70DAh | ICU              | Interrupt Request Register 218 | IR218              | 8                 | 8              | 2 ICLK                     | section 14.          |

Table 5.1 List of I/O Registers (Address Order) (3/13)

| Address    | Module<br>Symbol | Register Name                      | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|------------|------------------|------------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 70DBh | ICU              | Interrupt Request Register 219     | IR219              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70DCh | ICU              | Interrupt Request Register 220     | IR220              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70DDh | ICU              | Interrupt Request Register 221     | IR221              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70DEh | ICU              | Interrupt Request Register 222     | IR222              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70DFh | ICU              | Interrupt Request Register 223     | IR223              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70E0h | ICU              | Interrupt Request Register 224     | IR224              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70E1h | ICU              | Interrupt Request Register 225     | IR225              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70EEh | ICU              | Interrupt Request Register 238     | IR238              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70EFh | ICU              | Interrupt Request Register 239     | IR239              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70F0h | ICU              | Interrupt Request Register 240     | IR240              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70F1h | ICU              | Interrupt Request Register 241     | IR241              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70F2h | ICU              | Interrupt Request Register 242     | IR242              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70F3h | ICU              | Interrupt Request Register 243     | IR243              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70F4h | ICU              | Interrupt Request Register 244     | IR244              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70F5h | ICU              | Interrupt Request Register 245     | IR245              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70F6h | ICU              | Interrupt Request Register 246     | IR246              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70F7h | ICU              | Interrupt Request Register 247     | IR247              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70F8h | ICU              | Interrupt Request Register 248     | IR248              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 70F9h | ICU              | Interrupt Request Register 249     | IR249              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 711Bh | ICU              | DTC Activation Enable Register 027 | DTCER027           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 711Ch | ICU              | DTC Activation Enable Register 028 | DTCER028           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 711Dh | ICU              | DTC Activation Enable Register 029 | DTCER029           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 712Dh | ICU              | DTC Activation Enable Register 045 | DTCER045           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 712Eh | ICU              | DTC Activation Enable Register 046 | DTCER046           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7140h | ICU              | DTC Activation Enable Register 064 | DTCER064           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7141h | ICU              | DTC Activation Enable Register 065 | DTCER065           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7142h | ICU              | DTC Activation Enable Register 066 | DTCER066           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7143h | ICU              | DTC Activation Enable Register 067 | DTCER067           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7144h | ICU              | DTC Activation Enable Register 068 | DTCER068           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7145h | ICU              | DTC Activation Enable Register 069 | DTCER069           | 8                 | 8              | 2 ICLK                     |                      |
|            |                  | <u> </u>                           |                    |                   | 8              |                            | section 14.          |
| 0008 7146h | ICU              | DTC Activation Enable Register 070 | DTCER070           | 8                 |                | 2 ICLK                     | section 14.          |
| 0008 7147h | ICU              | DTC Activation Enable Register 071 | DTCER071           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7166h | ICU              | DTC Activation Enable Register 102 | DTCER102           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7167h | ICU              | DTC Activation Enable Register 103 | DICER103           | 8                 |                | 2 ICLK                     | section 14.          |
| 0008 7172h | ICU              | DTC Activation Enable Register 114 | DTCER114           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7173h | ICU              | DTC Activation Enable Register 115 | DTCER115           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7174h | ICU              | DTC Activation Enable Register 116 | DTCER116           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7175h | ICU              | DTC Activation Enable Register 117 | DTCER117           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7179h | ICU              | DTC Activation Enable Register 121 | DTCER121           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 717Ah | ICU              | DTC Activation Enable Register 122 | DTCER122           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 717Dh | ICU              | DTC Activation Enable Register 125 | DTCER125           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 717Eh | ICU              | DTC Activation Enable Register 126 | DTCER126           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 718Bh | ICU              | DTC Activation Enable Register 139 | DTCER139           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 718Ch | ICU              | DTC Activation Enable Register 140 | DTCER140           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 718Dh | ICU              | DTC Activation Enable Register 141 | DTCER141           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 71DBh | ICU              | DTC Activation Enable Register 219 | DTCER219           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 71DCh | ICU              | DTC Activation Enable Register 220 | DTCER220           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 71DFh | ICU              | DTC Activation Enable Register 223 | DTCER223           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 71E0h | ICU              | DTC Activation Enable Register 224 | DTCER224           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 71EFh | ICU              | DTC Activation Enable Register 239 | DTCER239           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 71F0h | ICU              | DTC Activation Enable Register 240 | DTCER240           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 71F7h | ICU              | DTC Activation Enable Register 247 | DTCER247           | 8                 | 8              | 2 ICLK                     | section 14.          |

Table 5.1 List of I/O Registers (Address Order) (4/13)

| Address    | Module<br>Symbol | Register Name                          | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|------------|------------------|----------------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 71F8h | ICU              | DTC Activation Enable Register 248     | DTCER248           | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7202h | ICU              | Interrupt Request Enable Register 02   | IER02              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7203h | ICU              | Interrupt Request Enable Register 03   | IER03              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7204h | ICU              | Interrupt Request Enable Register 04   | IER04              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7205h | ICU              | Interrupt Request Enable Register 05   | IER05              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7207h | ICU              | Interrupt Request Enable Register 07   | IER07              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7208h | ICU              | Interrupt Request Enable Register 08   | IER08              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 720Bh | ICU              | Interrupt Request Enable Register 0B   | IER0B              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 720Ch | ICU              | Interrupt Request Enable Register 0C   | IER0C              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 720Eh | ICU              | Interrupt Request Enable Register 0E   | IER0E              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 720Fh | ICU              | Interrupt Request Enable Register 0F   | IER0F              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7210h | ICU              | Interrupt Request Enable Register 10   | IER10              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7211h | ICU              | Interrupt Request Enable Register 11   | IER11              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 721Bh | ICU              | Interrupt Request Enable Register 1B   | IER1B              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 721Ch | ICU              | Interrupt Request Enable Register 1C   | IER1C              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 721Dh | ICU              | Interrupt Request Enable Register 1D   | IER1D              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 721Eh | ICU              | Interrupt Request Enable Register 1E   | IER1E              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 721Fh | ICU              | Interrupt Request Enable Register 1F   | IER1F              | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 72E0h | ICU              | Software Interrupt Activation Register | SWINTR             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 72F0h | ICU              | Fast Interrupt Set Register            | FIR                | 16                | 16             | 2 ICLK                     | section 14.          |
| 0008 7300h | ICU              | Interrupt Source Priority Register 000 | IPR000             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7303h | ICU              | Interrupt Source Priority Register 003 | IPR003             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7304h | ICU              | Interrupt Source Priority Register 004 | IPR004             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7305h | ICU              | Interrupt Source Priority Register 005 | IPR005             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7320h | ICU              | Interrupt Source Priority Register 032 | IPR032             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7321h | ICU              | Interrupt Source Priority Register 033 | IPR033             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7322h | ICU              | Interrupt Source Priority Register 034 | IPR034             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 732Ch | ICU              | Interrupt Source Priority Register 044 | IPR044             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7339h | ICU              | Interrupt Source Priority Register 057 | IPR057             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 733Fh | ICU              | Interrupt Source Priority Register 063 | IPR063             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7340h | ICU              | Interrupt Source Priority Register 064 | IPR064             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7341h | ICU              | Interrupt Source Priority Register 065 | IPR065             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7342h | ICU              | Interrupt Source Priority Register 066 | IPR066             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7343h | ICU              | Interrupt Source Priority Register 067 | IPR067             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7344h | ICU              | Interrupt Source Priority Register 068 | IPR068             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7345h | ICU              | Interrupt Source Priority Register 069 | IPR069             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7346h | ICU              | Interrupt Source Priority Register 070 | IPR070             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7347h | ICU              | Interrupt Source Priority Register 071 | IPR071             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7358h | ICU              | Interrupt Source Priority Register 088 | IPR088             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7359h | ICU              | Interrupt Source Priority Register 089 | IPR089             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 735Ch | ICU              | Interrupt Source Priority Register 092 | IPR092             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 735Dh | ICU              | Interrupt Source Priority Register 092 | IPR093             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 735DH | ICU              | Interrupt Source Priority Register 093 | IPR102             | 8                 | 8              | 2 ICLK                     | section 14.          |
|            |                  | · · · · · · · · · · · · · · · · · · ·  |                    |                   |                |                            |                      |
| 0008 7367h | ICU              | Interrupt Source Priority Register 103 | IPR103             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7372h | ICU              | Interrupt Source Priority Register 114 | IPR114             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7376h | ICU              | Interrupt Source Priority Register 118 | IPR118             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 7379h | ICU              | Interrupt Source Priority Register 121 | IPR121             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 737Bh | ICU              | Interrupt Source Priority Register 123 | IPR123             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 737Dh | ICU              | Interrupt Source Priority Register 125 | IPR125             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 737Fh | ICU              | Interrupt Source Priority Register 127 | IPR127             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 738Bh | ICU              | Interrupt Source Priority Register 139 | IPR139             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 73DAh | ICU              | Interrupt Source Priority Register 218 | IPR218             | 8                 | 8              | 2 ICLK                     | section 14.          |

Table 5.1 List of I/O Registers (Address Order) (5/13)

| Address    | Module<br>Symbol | Register Name                                            | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|------------|------------------|----------------------------------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 73DEh | ICU              | Interrupt Source Priority Register 222                   | IPR222             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 73EEh | ICU              | Interrupt Source Priority Register 238                   | IPR238             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 73F2h | ICU              | Interrupt Source Priority Register 242                   | IPR242             | 8                 | 8              | 2 ICLK                     | section 14.          |
| 0008 73F3h | ICU              | Interrupt Source Priority Register 243                   | IPR243             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 73F4h | ICU              | Interrupt Source Priority Register 244                   | IPR244             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 73F5h | ICU              | Interrupt Source Priority Register 245                   | IPR245             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 73F6h | ICU              | Interrupt Source Priority Register 246                   | IPR246             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 73F7h | ICU              | Interrupt Source Priority Register 247                   | IPR247             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 73F8h | ICU              | Interrupt Source Priority Register 248                   | IPR248             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 73F9h | ICU              | Interrupt Source Priority Register 249                   | IPR249             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 7500h | ICU              | IRQ Control Register 0                                   | IRQCR0             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 7501h | ICU              | IRQ Control Register 1                                   | IRQCR1             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 7502h | ICU              | IRQ Control Register 2                                   | IRQCR2             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 7503h | ICU              | IRQ Control Register 3                                   | IRQCR3             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 7504h | ICU              | IRQ Control Register 4                                   | IRQCR4             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 7505h | ICU              | IRQ Control Register 5                                   | IRQCR5             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 7506h | ICU              | IRQ Control Register 6                                   | IRQCR6             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 7507h | ICU              | IRQ Control Register 7                                   | IRQCR7             | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 7510h | ICU              | IRQ Pin Digital Filter Enable Register 0                 | IRQFLTE0           | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 7514h | ICU              | IRQ Pin Digital Filter Setting Register 0                | IRQFLTC0           | 16                | 16             | 2 ICLK                     | section 14           |
| 008 7580h  | ICU              | Non-Maskable Interrupt Status Register                   | NMISR              | 8                 | 8              | 2 ICLK                     | section 14           |
| 008 7581h  | ICU              | Non-Maskable Interrupt Enable Register                   | NMIER              | 8                 | 8              | 2 ICLK                     | section 14           |
| 008 7582h  | ICU              | Non-Maskable Interrupt Status Clear Register             | NMICLR             | 8                 | 8              | 2 ICLK                     | section 14           |
| 008 7583h  | ICU              | NMI Pin Interrupt Control Register                       | NMICR              | 8                 | 8              | 2 ICLK                     | section 14           |
| 008 7590h  | ICU              | NMI Pin Digital Filter Enable Register                   | NMIFLTE            | 8                 | 8              | 2 ICLK                     | section 14           |
| 008 7594h  | ICU              | NMI Pin Digital Filter Setting Register                  | NMIFLTC            | 8                 | 8              | 2 ICLK                     | section 14           |
| 0008 8000h | CMT              | Compare Match Timer Start Register 0                     | CMSTR0             | 16                | 16             | 2 or 3 PCLKB               | section 20           |
| 008 8002h  | CMT0             | Compare Match Timer Control Register                     | CMCR               | 16                | 16             | 2 or 3 PCLKB               | section 20           |
| 0008 8004h | CMT0             | Compare Match Timer Counter  Compare Match Timer Counter | CMCNT              | 16                | 16             | 2 or 3 PCLKB               | section 20           |
| 0008 8006h | CMT0             | ·                                                        | CMCOR              | 16                | 16             | 2 or 3 PCLKB               | section 20           |
|            | CMT1             | Compare Match Timer Control Register                     |                    |                   |                | 2 or 3 PCLKB               |                      |
| 0008 8008h |                  | Compare Match Timer Country                              | CMCNT              | 16                | 16             |                            | section 20           |
| 0008 800Ah | CMT1             | Compare Match Timer Constant Position                    | CMCOR              | 16                | 16             | 2 or 3 PCLKB               | section 20           |
| 0008 800Ch | CMT1             | Compare Match Timer Constant Register                    | CMCOR              | 16                | 16             | 2 or 3 PCLKB               | section 20           |
| 0008 8030h | IWDT             | IWDT Refresh Register                                    | IWDTRR             | 8                 | 8              | 2 or 3 PCLKB               | section 22           |
| 0008 8032h | IWDT             | IWDT Control Register                                    | IWDTCR             | 16                | 16             | 2 or 3 PCLKB               | section 22           |
| 0008 8034h | IWDT             | IWDT Status Register                                     | IWDTSR             | 16                | 16             | 2 or 3 PCLKB               | section 22           |
| 0008 8036h | IWDT             | IWDT Reset Control Register                              | IWDTRCR            | 8                 | 8              | 2 or 3 PCLKB               | section 22           |
| 0008 8038h | IWDT             | IWDT Count Stop Control Register                         | IWDTCSTPR          | 8                 | 8              | 2 or 3 PCLKB               | section 22           |
| 0008 8280h | CRC              | CRC Control Register                                     | CRCCR              | 8                 | 8              | 2 or 3 PCLKB               | section 26           |
| 0008 8281h | CRC              | CRC Data Input Register                                  | CRCDIR             | 8                 | 8              | 2 or 3 PCLKB               | section 26           |
| 0008 8282h | CRC              | CRC Data Output Register                                 | CRCDOR             | 16                | 16             | 2 or 3 PCLKB               | section 26           |
| 0008 8300h | RIIC0            | I <sup>2</sup> C Bus Control Register 1                  | ICCR1              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 8301h | RIIC0            | I <sup>2</sup> C Bus Control Register 2                  | ICCR2              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 008 8302h  | RIIC0            | I <sup>2</sup> C Bus Mode Register 1                     | ICMR1              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 008 8303h  | RIIC0            | I <sup>2</sup> C Bus Mode Register 2                     | ICMR2              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 008 8304h  | RIIC0            | I <sup>2</sup> C Bus Mode Register 3                     | ICMR3              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 8305h | RIIC0            | I <sup>2</sup> C Bus Function Enable Register            | ICFER              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 008 8306h  | RIIC0            | I <sup>2</sup> C Bus Status Enable Register              | ICSER              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 008 8307h  | RIIC0            | I <sup>2</sup> C Bus Interrupt Enable Register           | ICIER              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 008 8308h  | RIIC0            | I <sup>2</sup> C Bus Status Register 1                   | ICSR1              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 008 8309h  | RIIC0            | I <sup>2</sup> C Bus Status Register 2                   | ICSR2              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 008 830Ah  | RIIC0            | Slave Address Register L0                                | SARL0              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |

Table 5.1 List of I/O Registers (Address Order) (6/13)

| Address    | Module<br>Symbol | Register Name                                     | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|------------|------------------|---------------------------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 830Ah | RIIC0            | Timeout Internal Counter L                        | TMOCNTL            | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 830Bh | RIIC0            | Slave Address Register U0                         | SARU0              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 830Bh | RIIC0            | Timeout Internal Counter U                        | TMOCNTU            | 8                 | 8 *1           | 2 or 3 PCLKB               | section 24           |
| 0008 830Ch | RIIC0            | Slave Address Register L1                         | SARL1              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 830Dh | RIIC0            | Slave Address Register U1                         | SARU1              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 830Eh | RIIC0            | Slave Address Register L2                         | SARL2              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 830Fh | RIIC0            | Slave Address Register U2                         | SARU2              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 8310h | RIIC0            | I <sup>2</sup> C Bus Bit Rate Low-Level Register  | ICBRL              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 8311h | RIIC0            | I <sup>2</sup> C Bus Bit Rate High-Level Register | ICBRH              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 8312h | RIIC0            | I <sup>2</sup> C Bus Transmit Data Register       | ICDRT              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 0008 8313h | RIIC0            | I <sup>2</sup> C Bus Receive Data Register        | ICDRR              | 8                 | 8              | 2 or 3 PCLKB               | section 24           |
| 008 8380h  | RSPI0            | RSPI Control Register                             | SPCR               | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 0008 8381h | RSPI0            | RSPI Slave Select Polarity Register               | SSLP               | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 0008 8382h | RSPI0            | RSPI Pin Control Register                         | SPPCR              | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 0008 8383h | RSPI0            | RSPI Status Register                              | SPSR               | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 008 8384h  | RSPI0            | RSPI Data Register                                | SPDR               | 32                | 16, 32         | 2 or 3 PCLKB/2ICLK         | section 25           |
| 008 8388h  | RSPI0            | RSPI Sequence Control Register                    | SPSCR              | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 008 8389h  | RSPI0            | RSPI Sequence Status Register                     | SPSSR              | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 008 838Ah  | RSPI0            | RSPI Bit Rate Register                            | SPBR               | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 008 838Bh  | RSPI0            | RSPI Data Control Register                        | SPDCR              | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 008 838Ch  | RSPI0            | RSPI Clock Delay Register                         | SPCKD              | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 008 838Dh  | RSPI0            | RSPI Slave Select Negation Delay Register         | SSLND              | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 008 838Eh  | RSPI0            | RSPI Next-Access Delay Register                   | SPND               | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 008 838Fh  | RSPI0            | RSPI Control Register 2                           | SPCR2              | 8                 | 8              | 2 or 3 PCLKB               | section 25           |
| 008 8390h  | RSPI0            | RSPI Command Register 0                           | SPCMD0             | 16                | 16             | 2 or 3 PCLKB               | section 25           |
| 008 8392h  | RSPI0            | •                                                 | SPCMD1             | 16                | 16             | 2 or 3 PCLKB               |                      |
|            |                  | RSPI Command Register 1                           |                    |                   |                |                            | section 25           |
| 008 8394h  | RSPI0            | RSPI Command Register 2                           | SPCMD2             | 16                | 16             | 2 or 3 PCLKB               | section 25           |
| 008 8396h  | RSPI0            | RSPI Command Register 3                           | SPCMD3             | 16                | 16             | 2 or 3 PCLKB               | section 25           |
| 008 8398h  | RSPI0            | RSPI Command Register 4                           | SPCMD4             | 16                | 16             | 2 or 3 PCLKB               | section 25           |
| 008 839Ah  | RSPI0            | RSPI Command Register 5                           | SPCMD5             | 16                | 16             | 2 or 3 PCLKB               | section 25           |
| 008 839Ch  | RSPI0            | RSPI Command Register 6                           | SPCMD6             | 16                | 16             | 2 or 3 PCLKB               | section 25           |
| 008 839Eh  | RSPI0            | RSPI Command Register 7                           | SPCMD7             | 16                | 16             | 2 or 3 PCLKB               | section 25           |
| 008 8680h  | MTU              | Timer Start Register                              | TSTR               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 19           |
| 008 8681h  | MTU              | Timer Synchronous Register                        | TSYR               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 19           |
| 008 8690h  | MTU0             | Noise Filter Control Register                     | NFCR               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 19           |
| 008 8691h  | MTU1             | Noise Filter Control Register                     | NFCR               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 19           |
| 008 8692h  | MTU2             | Noise Filter Control Register                     | NFCR               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 19           |
| 008 8695h  | MTU5             | Noise Filter Control Register                     | NFCR               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 19           |
| 008 8700h  | MTU0             | Timer Control Register                            | TCR                | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 8701h  | MTU0             | Timer Mode Register                               | TMDR               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 8702h  | MTU0             | Timer I/O Control Register H                      | TIORH              | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 8703h  | MTU0             | Timer I/O Control Register L                      | TIORL              | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 8704h  | MTU0             | Timer Interrupt Enable Register                   | TIER               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 8705h  | MTU0             | Timer Status Register                             | TSR                | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 8706h  | MTU0             | Timer Counter                                     | TCNT               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 008 8708h  | MTU0             | Timer General Register A                          | TGRA               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 008 870Ah  | MTU0             | Timer General Register B                          | TGRB               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 008 870Ch  | MTU0             | Timer General Register C                          | TGRC               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 008 870Eh  | MTU0             | Timer General Register D                          | TGRD               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 008 8720h  | MTU0             | Timer General Register E                          | TGRE               | 16                | 16             | 2 or 3 PCLKB               | section 1            |
| 008 8722h  | MTU0             | Timer General Register F                          | TGRF               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
|            |                  | · · · · · · · · · · · · · · · · · · ·             | -                  |                   | -              |                            |                      |

Table 5.1 List of I/O Registers (Address Order) (7/13)

| Address    | Module<br>Symbol | Register Name                                                                    | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|------------|------------------|----------------------------------------------------------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 8726h | MTU0             | Timer Buffer Operation Transfer Mode Register                                    | TBTM               | 8                 | 8              | 2 or 3 PCLKB               | section 19.          |
| 0008 8780h | MTU1             | Timer Control Register                                                           | TCR                | 8                 | 8              | 2 or 3 PCLKB               | section 19.          |
| 0008 8781h | MTU1             | Timer Mode Register                                                              | TMDR               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8782h | MTU1             | Timer I/O Control Register                                                       | TIOR               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8784h | MTU1             | Timer Interrupt Enable Register                                                  | TIER               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8785h | MTU1             | Timer Status Register                                                            | TSR                | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8786h | MTU1             | Timer Counter                                                                    | TCNT               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 0008 8788h | MTU1             | Timer General Register A                                                         | TGRA               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 0008 878Ah | MTU1             | Timer General Register B                                                         | TGRB               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 0008 8790h | MTU1             | Timer Input Capture Control Register                                             | TICCR              | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8800h | MTU2             | Timer Control Register                                                           | TCR                | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8801h | MTU2             | Timer Mode Register                                                              | TMDR               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8802h | MTU2             | Timer I/O Control Register                                                       | TIOR               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8804h | MTU2             | Timer Interrupt Enable Register                                                  | TIER               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8805h | MTU2             | Timer Status Register                                                            | TSR                | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8806h | MTU2             | Timer Counter                                                                    | TCNT               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 0008 8808h | MTU2             | Timer General Register A                                                         | TGRA               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 0008 880Ah | MTU2             | Timer General Register B                                                         | TGRB               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 0008 8880h | MTU5             | Timer Counter U                                                                  | TCNTU              | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 008 8882h  | MTU5             | Timer General Register U                                                         | TGRU               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 0008 8884h | MTU5             | Timer Control Register U                                                         | TCRU               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 8886h | MTU5             | Timer I/O Control Register U                                                     | TIORU              | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 8890h  | MTU5             | Timer Counter V                                                                  | TCNTV              | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 008 8892h  | MTU5             | Timer General Register V                                                         | TGRV               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 008 8894h  | MTU5             | Timer Control Register V                                                         | TCRV               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 8896h  | MTU5             | Timer I/O Control Register V                                                     | TIORV              | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 88A0h | MTU5             | Timer Counter W                                                                  | TCNTW              | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 0008 88A2h | MTU5             | Timer General Register W                                                         | TGRW               | 16                | 16             | 2 or 3 PCLKB               | section 19           |
| 0008 88A4h | MTU5             | Timer Control Register W                                                         | TCRW               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 88A6h | MTU5             | Timer I/O Control Register W                                                     | TIORW              | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 88B2h | MTU5             | Timer Interrupt Enable Register                                                  | TIER               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 88B4h | MTU5             | Timer Start Register                                                             | TSTR               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 88B6h | MTU5             | Timer Compare Match Clear Register                                               | TCNTCMPCLR         | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 9000h | S12AD            | A/D Control Register                                                             | ADCSR              | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9004h | S12AD            | A/D Channel Select Register A                                                    | ADANSA             | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9008h | S12AD            | A/D-Converted Value Addition Mode Select Register                                | ADADS              | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9006H | S12AD            | A/D-Converted Value Addition Fount Select Register                               | ADADC              | 8                 | 8              | 2 or 3 PCLKB               | section 27           |
| 0008 900Eh | S12AD            | A/D Control Extended Register                                                    | ADCER              | 16                | 16             | 2 or 3 PCLKB               | section 27           |
|            | S12AD            | •                                                                                | ADSTRGR            |                   |                | 2 or 3 PCLKB               |                      |
| 0008 9010h |                  | A/D Start Trigger Select Register  A/D Converted Extended Input Control Register |                    | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9012h | S12AD            |                                                                                  | ADANICR            | 16                | 16             |                            |                      |
| 0008 9014h | S12AD            | A/D Channel Select Register B                                                    | ADDRUBE            | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9018h | S12AD            | A/D Data Duplication Register                                                    | ADDBLDR            | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 901Ah | S12AD            | A/D Temperature Sensor Data Register                                             | ADTSDR             | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 901Ch | S12AD            | A/D Internal Reference Voltage Data Register                                     | ADOCDR             | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9020h | S12AD            | A/D Data Register 0                                                              | ADDR0              | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9022h | S12AD            | A/D Data Register 1                                                              | ADDR1              | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9024h | S12AD            | A/D Data Register 2                                                              | ADDR2              | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9026h | S12AD            | A/D Data Register 3                                                              | ADDR3              | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9028h | S12AD            | A/D Data Register 4                                                              | ADDR4              | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 008 902Ch  | S12AD            | A/D Data Register 6                                                              | ADDR6              | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 008 9030h  | S12AD            | A/D Data Register 8                                                              | ADDR8              | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 008 9032h  | S12AD            | A/D Data Register 9                                                              | ADDR9              | 16                | 16             | 2 or 3 PCLKB               | section 27           |

Table 5.1 List of I/O Registers (Address Order) (8/13)

| Address    | Module<br>Symbol | Register Name                          | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|------------|------------------|----------------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 9034h | S12AD            | A/D Data Register 10                   | ADDR10             | 16                | 16             | 2 or 3 PCLKB               | section 27.          |
| 0008 9036h | S12AD            | A/D Data Register 11                   | ADDR11             | 16                | 16             | 2 or 3 PCLKB               | section 27.          |
| 0008 9038h | S12AD            | A/D Data Register 12                   | ADDR12             | 16                | 16             | 2 or 3 PCLKB               | section 27.          |
| 0008 903Ah | S12AD            | A/D Data Register 13                   | ADDR13             | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 903Ch | S12AD            | A/D Data Register 14                   | ADDR14             | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 903Eh | S12AD            | A/D Data Register 15                   | ADDR15             | 16                | 16             | 2 or 3 PCLKB               | section 27           |
| 0008 9060h | S12AD            | A/D Sampling State Register 0          | ADSSTR0            | 8                 | 8              | 2 or 3 PCLKB               | section 27           |
| 0008 9061h | S12AD            | A/D Sampling State Register L          | ADSSTRL            | 8                 | 8              | 2 or 3 PCLKB               | section 27           |
| 0008 9070h | S12AD            | A/D Sampling State Register T          | ADSSTRT            | 8                 | 8              | 2 or 3 PCLKB               | section 27           |
| 0008 9071h | S12AD            | A/D Sampling State Register O          | ADSSTRO            | 8                 | 8              | 2 or 3 PCLKB               | section 27           |
| 0008 9073h | S12AD            | A/D Sampling State Register 1          | ADSSTR1            | 8                 | 8              | 2 or 3 PCLKB               | section 27           |
| 0008 9074h | S12AD            | A/D Sampling State Register 2          | ADSSTR2            | 8                 | 8              | 2 or 3 PCLKB               | section 27           |
| 0008 9075h | S12AD            | A/D Sampling State Register 3          | ADSSTR3            | 8                 | 8              | 2 or 3 PCLKB               | section 27           |
| 0008 9076h | S12AD            | A/D Sampling State Register 4          | ADSSTR4            | 8                 | 8              | 2 or 3 PCLKB               | section 27           |
| 0008 9078h | S12AD            | A/D Sampling State Register 6          | ADSSTR6            | 8                 | 8              | 2 or 3 PCLKB               | section 27           |
| 0008 A020h | SCI1             | Serial Mode Register                   | SMR                | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A021h | SCI1             | Bit Rate Register                      | BRR                | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A022h | SCI1             | Serial Control Register                | SCR                | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A023h | SCI1             | Transmit Data Register                 | TDR                | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A024h | SCI1             | Serial Status Register                 | SSR                | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A025h | SCI1             | Receive Data Register                  | RDR                | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 008 A026h  | SCI1             | Smart Card Mode Register               | SCMR               | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A027h | SCI1             | Serial Extended Mode Register          | SEMR               | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 008 A028h  | SCI1             | Noise Filter Setting Register          | SNFR               | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 008 A029h  | SCI1             | I <sup>2</sup> C Mode Register 1       | SIMR1              | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A02Ah | SCI1             | I <sup>2</sup> C Mode Register 2       | SIMR2              | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A02Bh | SCI1             | I <sup>2</sup> C Mode Register 3       | SIMR3              | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A02Ch | SCI1             | I <sup>2</sup> C Status Register       | SISR               | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A02CH | SCI1             | SPI Mode Register                      | SPMR               | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0A0h | SCI5             |                                        | SMR                | 8                 | 8              | 2 or 3 PCLKB               |                      |
|            | SCI5             | Serial Mode Register                   |                    | 8                 | 8              |                            | section 23           |
| 0008 A0A1h |                  | Bit Rate Register                      | BRR                |                   |                | 2 or 3 PCLKB               | section 23           |
| 0008 A0A2h | SCI5             | Serial Control Register                | SCR                | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0A3h | SCI5             | Transmit Data Register                 | TDR                | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0A4h | SCI5             | Serial Status Register                 | SSR                | - 8               | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0A5h | SCI5             | Receive Data Register                  | RDR                | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0A6h | SCI5             | Smart Card Mode Register               | SCMR               | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0A7h | SCI5             | Serial Extended Mode Register          | SEMR               | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0A8h | SCI5             | Noise Filter Setting Register          | SNFR               | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0A9h | SCI5             | I <sup>2</sup> C Mode Register 1       | SIMR1              | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0AAh | SCI5             | I <sup>2</sup> C Mode Register 2       | SIMR2              | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0ABh | SCI5             | I <sup>2</sup> C Mode Register 3       | SIMR3              | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0ACh | SCI5             | I <sup>2</sup> C Status Register       | SISR               | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 A0ADh | SCI5             | SPI Mode Register                      | SPMR               | 8                 | 8              | 2 or 3 PCLKB               | section 23           |
| 0008 B000h | CAC              | CAC Control Register 0                 | CACR0              | 8                 | 8              | 2 or 3 PCLKB               | section 10           |
| 0008 B001h | CAC              | CAC Control Register 1                 | CACR1              | 8                 | 8              | 2 or 3 PCLKB               | section 10           |
| 0008 B002h | CAC              | CAC Control Register 2                 | CACR2              | 8                 | 8              | 2 or 3 PCLKB               | section 10           |
| 0008 B003h | CAC              | CAC Interrupt Request Enable Register  | CAICR              | 8                 | 8              | 2 or 3 PCLKB               | section 10           |
| 0008 B004h | CAC              | CAC Status Register                    | CASTR              | 8                 | 8              | 2 or 3 PCLKB               | section 10           |
| 0008 B006h | CAC              | CAC Upper-Limit Value Setting Register | CAULVR             | 16                | 16             | 2 or 3 PCLKB               | section 10           |
| 0008 B008h | CAC              | CAC Lower-Limit Value Setting Register | CALLVR             | 16                | 16             | 2 or 3 PCLKB               | section 10           |
| 0008 B00Ah | CAC              | CAC Counter Buffer Register            | CACNTBR            | 16                | 16             | 2 or 3 PCLKB               | section 10           |
| 0008 B080h | DOC              | DOC Control Register                   | DOCR               | 8                 | 8              | 2 or 3 PCLKB               | section 29           |

Table 5.1 List of I/O Registers (Address Order) (9/13)

| Address    | Module<br>Symbol | Register Name                           | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|------------|------------------|-----------------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 B082h | DOC              | DOC Data Input Register                 | DODIR              | 16                | 16             | 2 or 3 PCLKB               | section 29.          |
| 0008 B084h | DOC              | DOC Data Setting Register               | DODSR              | 16                | 16             | 2 or 3 PCLKB               | section 29.          |
| 0008 B300h | SCI12            | Serial Mode Register                    | SMR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B301h | SCI12            | Bit Rate Register                       | BRR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B302h | SCI12            | Serial Control Register                 | SCR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B303h | SCI12            | Transmit Data Register                  | TDR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B304h | SCI12            | Serial Status Register                  | SSR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B305h | SCI12            | Receive Data Register                   | RDR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B306h | SCI12            | Smart Card Mode Register                | SCMR               | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B307h | SCI12            | Serial Extended Mode Register           | SEMR               | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B308h | SCI12            | Noise Filter Setting Register           | SNFR               | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B309h | SCI12            | I <sup>2</sup> C Mode Register 1        | SIMR1              | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B30Ah | SCI12            | I <sup>2</sup> C Mode Register 2        | SIMR2              | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B30Bh | SCI12            | I <sup>2</sup> C Mode Register 3        | SIMR3              | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B30Ch | SCI12            | I <sup>2</sup> C Status Register        | SISR               | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B30Dh | SCI12            | SPI Mode Register                       | SPMR               | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B320h | SCI12            | Extended Serial Mode Enable Register    | ESMER              | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B321h | SCI12            | Control Register 0                      | CR0                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B322h | SCI12            | Control Register 1                      | CR1                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B323h | SCI12            | Control Register 2                      | CR2                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B324h | SCI12            | Control Register 3                      | CR3                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B325h | SCI12            | Port Control Register                   | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B326h | SCI12            | Interrupt Control Register              | ICR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B327h | SCI12            | Status Register                         | STR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B328h | SCI12            | Status Clear Register                   | STCR               | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B329h | SCI12            | Control Field 0 Data Register           | CF0DR              | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B32Ah | SCI12            |                                         | CF0CR              | 8                 | 8              | 2 or 3 PCLKB               |                      |
|            |                  | Control Field 0 Compare Enable Register |                    |                   |                |                            | section 23.          |
| 0008 B32Bh | SCI12            | Control Field 0 Receive Data Register   | CF0RR<br>PCF1DR    | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B32Ch | SCI12            | Primary Control Field 1 Data Register   |                    |                   |                | 2 or 3 PCLKB               |                      |
| 0008 B32Dh | SCI12            | Secondary Control Field 1 Data Register | SCF1DR             | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B32Eh | SCI12            | Control Field 1 Compare Enable Register | CF1CR              | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B32Fh | SCI12            | Control Field 1 Receive Data Register   | CF1RR              | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B330h | SCI12            | Timer Control Register                  | TCR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B331h | SCI12            | Timer Mode Register                     | IMR                | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B332h | SCI12            | Timer Prescaler Register                | TPRE               | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 B333h | SCI12            | Timer Count Register                    | TCNT               | 8                 | 8              | 2 or 3 PCLKB               | section 23.          |
| 0008 C000h | PORT0            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C001h | PORT1            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C002h | PORT2            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C003h | PORT3            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C004h | PORT4            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C005h | PORT5            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C00Ah | PORTA            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C00Bh | PORTB            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C00Ch | PORTC            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C00Eh | PORTE            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C011h | PORTH            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C012h | PORTJ            | Port Direction Register                 | PDR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C020h | PORT0            | Port Output Data Register               | PODR               | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C021h | PORT1            | Port Output Data Register               | PODR               | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C022h | PORT2            | Port Output Data Register               | PODR               | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C023h | PORT3            | Port Output Data Register               | PODR               | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |

Table 5.1 List of I/O Registers (Address Order) (10/13)

| Address    | Module<br>Symbol | Register Name             | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States                                                  | Reference<br>Section |
|------------|------------------|---------------------------|--------------------|-------------------|----------------|-----------------------------------------------------------------------------|----------------------|
| 0008 C024h | PORT4            | Port Output Data Register | PODR               | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C025h | PORT5            | Port Output Data Register | PODR               | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C02Ah | PORTA            | Port Output Data Register | PODR               | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C02Bh | PORTB            | Port Output Data Register | PODR               | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C02Ch | PORTC            | Port Output Data Register | PODR               | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C02Eh | PORTE            | Port Output Data Register | PODR               | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C031h | PORTH            | Port Output Data Register | PODR               | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C032h | PORTJ            | Port Output Data Register | PODR               | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C040h | PORT0            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C041h | PORT1            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C042h | PORT2            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C043h | PORT3            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C044h | PORT4            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C045h | PORT5            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C04Ah | PORTA            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C04Bh | PORTB            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C04Ch | PORTC            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C04Eh | PORTE            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C051h | PORTH            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C052h | PORTJ            | Port Input Data Register  | PIDR               | 8                 | 8              | 3 or 4 PCLKB cycles<br>when reading,<br>2 or 3 PCLKB cycles<br>when writing | section 18.          |
| 0008 C060h | PORT0            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C061h | PORT1            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C062h | PORT2            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C063h | PORT3            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C064h | PORT4            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C065h | PORT5            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C06Ah | PORTA            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C06Bh | PORTB            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C06Ch | PORTC            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C06Eh | PORTE            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C071h | PORTH            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |
| 0008 C072h | PORTJ            | Port Mode Register        | PMR                | 8                 | 8              | 2 or 3 PCLKB                                                                | section 18.          |

Table 5.1 List of I/O Registers (Address Order) (11/13)

| Address     | Module<br>Symbol | Register Name                     | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|-------------|------------------|-----------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 C083h  | PORT1            | Open Drain Control Register 1     | ODR1               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C085h  | PORT2            | Open Drain Control Register 1     | ODR1               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C086h  | PORT3            | Open Drain Control Register 0     | ODR0               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C094h  | PORTA            | Open Drain Control Register 0     | ODR0               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C095h  | PORTA            | Open Drain Control Register 1     | ODR1               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C096h  | PORTB            | Open Drain Control Register 0     | ODR0               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C097h  | PORTB            | Open Drain Control Register 1     | ODR1               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C098h  | PORTC            | Open Drain Control Register 0     | ODR0               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C099h  | PORTC            | Open Drain Control Register 1     | ODR1               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C09Ch  | PORTE            | Open Drain Control Register 0     | ODR0               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C09Dh  | PORTE            | Open Drain Control Register 1     | ODR1               | 8                 | 8, 16          | 2 or 3 PCLKB               | section 18.          |
| 0008 C0C0h  | PORT0            | Pull-Up Control Register          | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 18           |
| 0008 C0C1h  | PORT1            | Pull-Up Control Register          | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C0C2h  | PORT2            | Pull-Up Control Register          | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 0008 C0C3h  | PORT3            | Pull-Up Control Register          | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 18.          |
| 008 C0C5h   | PORT5            | Pull-Up Control Register          | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 18           |
| 008 C0CAh   | PORTA            | Pull-Up Control Register          | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 18           |
| 008 C0CBh   | PORTB            | Pull-Up Control Register          | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 18           |
| 008 C0CCh   | PORTC            | Pull-Up Control Register          | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 18           |
| 008 C0CEh   | PORTE            | Pull-Up Control Register          | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 18           |
| 008 C0D1h   | PORTH            | Pull-Up Control Register          | PCR                | 8                 | 8              | 2 or 3 PCLKB               | section 18           |
| 008 C11Fh   | MPC              | Write-Protect Register            | PWPR               | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C120h   | PORT             | Port Switching Register B         | PSRB               | 8                 | 8              | 2 or 3 PCLKB               | section 18           |
| 008 C121h   | PORT             | Port Switching Register A         | PSRA               | 8                 | 8              | 2 or 3 PCLKB               | section 18           |
| 008 C14Ch   | MPC              | P14 Pin Function Control Register | P14PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C14Dh   | MPC              | P15 Pin Function Control Register | P15PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C14Eh   | MPC              | P16 Pin Function Control Register | P16PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C14Fh  | MPC              | P17 Pin Function Control Register | P17PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C141 H | MPC              | P26 Pin Function Control Register | P26PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C157h  | MPC              |                                   | P27PFS             | 8                 | 8              | 2 or 3 PCLKB               |                      |
|             | MPC              | P27 Pin Function Control Register |                    |                   | 8              |                            | section 19           |
| 0008 C158h  |                  | P30 Pin Function Control Register | P30PFS             | 8                 |                | 2 or 3 PCLKB               | section 19           |
| 0008 C159h  | MPC              | P31 Pin Function Control Register | P31PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C15Ah  | MPC              | P32 Pin Function Control Register | P32PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C160h  | MPC              | P40 Pin Function Control Register | P40PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C161h  | MPC              | P41 Pin Function Control Register | P41PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C162h  | MPC              | P42 Pin Function Control Register | P42PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C163h   | MPC              | P43 Pin Function Control Register | P43PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C164h  | MPC              | P44 Pin Function Control Register | P44PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C166h   | MPC              | P46 Pin Function Control Register | P46PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C190h  | MPC              | PA0 Pin Function Control Register | PA0PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C191h   | MPC              | PA1 Pin Function Control Register | PA1PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C193h  | MPC              | PA3 Pin Function Control Register | PA3PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C194h  | MPC              | PA4 Pin Function Control Register | PA4PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C196h   | MPC              | PA6 Pin Function Control Register | PA6PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C198h   | MPC              | PB0 Pin Function Control Register | PB0PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C199h  | MPC              | PB1 Pin Function Control Register | PB1PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C19Bh  | MPC              | PB3 Pin Function Control Register | PB3PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C19Dh   | MPC              | PB5 Pin Function Control Register | PB5PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 0008 C19Eh  | MPC              | PB6 Pin Function Control Register | PB6PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C19Fh   | MPC              | PB7 Pin Function Control Register | PB7PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C1A2h   | MPC              | PC2 Pin Function Control Register | PC2PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |
| 008 C1A3h   | MPC              | PC3 Pin Function Control Register | PC3PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19           |

Table 5.1 List of I/O Registers (Address Order) (12/13)

| Address    | Module<br>Symbol | Register Name                                             | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section     |
|------------|------------------|-----------------------------------------------------------|--------------------|-------------------|----------------|----------------------------|--------------------------|
| 0008 C1A4h | MPC              | PC4 Pin Function Control Register                         | PC4PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19.              |
| 0008 C1A5h | MPC              | PC5 Pin Function Control Register                         | PC5PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19.              |
| 0008 C1A6h | MPC              | PC6 Pin Function Control Register                         | PC6PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19.              |
| 0008 C1A7h | MPC              | PC7 Pin Function Control Register                         | PC7PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19.              |
| 0008 C1B0h | MPC              | PE0 Pin Function Control Register                         | PE0PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1B1h | MPC              | PE1 Pin Function Control Register                         | PE1PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1B2h | MPC              | PE2 Pin Function Control Register                         | PE2PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1B3h | MPC              | PE3 Pin Function Control Register                         | PE3PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1B4h | MPC              | PE4 Pin Function Control Register                         | PE4PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1B5h | MPC              | PE5 Pin Function Control Register                         | PE5PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1B6h | MPC              | PE6 Pin Function Control Register                         | PE6PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1B7h | MPC              | PE7 Pin Function Control Register                         | PE7PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1C8h | MPC              | PH0 Pin Function Control Register                         | PH0PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1C9h | MPC              | PH1 Pin Function Control Register                         | PH1PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1CAh | MPC              | PH2 Pin Function Control Register                         | PH2PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1CBh | MPC              | PH3 Pin Function Control Register                         | PH3PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1D6h | MPC              | PJ6 Pin Function Control Register                         | PJ6PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C1D7h | MPC              | PJ7 Pin Function Control Register                         | PJ7PFS             | 8                 | 8              | 2 or 3 PCLKB               | section 19               |
| 0008 C290h | SYSTEM           | Reset Status Register 0                                   | RSTSR0             | 8                 | 8              | 4 or 5 PCLKB               | section 6.               |
| 0008 C291h | SYSTEM           | Reset Status Register 1                                   | RSTSR1             | 8                 | 8              | 4 or 5 PCLKB               | section 6                |
| 0008 C293h | SYSTEM           | Main Clock Oscillator Forced Oscillation Control Register | MOFCR              | 8                 | 8              | 4 or 5 PCLKB               | section 9                |
| 008 C297h  | SYSTEM           | Voltage Monitoring Circuit Control Register               | LVCMPCR            | 8                 | 8              | 4 or 5 PCLKB               | section 8                |
| 008 C298h  | SYSTEM           | Voltage Detection Level Select Register                   | LVDLVLR            | 8                 | 8              | 4 or 5 PCLKB               | section 8                |
| 008 C29Ah  | SYSTEM           | Voltage Monitoring 1 Circuit Control Register 0           | LVD1CR0            | 8                 | 8              | 4 or 5 PCLKB               | section 8                |
| 008 C29Bh  | SYSTEM           | Voltage Monitoring 2 Circuit Control Register 0           | LVD2CR0            | 8                 | 8              | 4 or 5 PCLKB               | section 8                |
| 0008 C400h | RTC              | 64-Hz Counter                                             | R64CNT             | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C402h | RTC              | Second Counter                                            | RSECCNT            | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C402h | RTC              | Binary Counter 0                                          | BCNT0              | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C404h | RTC              | Minute Counter                                            | RMINCNT            | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C404h | RTC              | Binary Counter 1                                          | BCNT1              | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C406h | RTC              | Hour Counter                                              | RHRCNT             | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C406h | RTC              | Binary Counter 2                                          | BCNT2              | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C408h | RTC              | Day-Of-Week Counter                                       | RWKCNT             | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C408h | RTC              | Binary Counter 3                                          | BCNT3              | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C40Ah | RTC              | Date Counter                                              | RDAYCNT            | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C40Ch | RTC              | Month Counter                                             | RMONCNT            | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C40Eh | RTC              | Year Counter                                              | RYRCNT             | 16                | 16             | 2 or 3 PCLKB               | section 21               |
| 0008 C410h | RTC              | Second Alarm Register                                     | RSECAR             | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C410h | RTC              | Binary Counter 0 Alarm Register                           | BCNT0AR            | 8                 | 8              | 2 or 3 PCLKB               |                          |
| 0008 C410H | RTC              | Minute Alarm Register                                     | RMINAR             | 8                 | 8              | 2 or 3 PCLKB               | section 21<br>section 21 |
|            |                  | Binary Counter 1 Alarm Register                           |                    |                   |                |                            |                          |
| 0008 C412h | RTC              | <u>,                                     </u>             | BCNT1AR            | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C414h | RTC              | Hour Alarm Register                                       | RHRAR              | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C414h | RTC              | Binary Counter 2 Alarm Register                           | BCNT2AR            | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C416h | RTC              | Day-of-Week Alarm Register                                | RWKAR              | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C416h | RTC              | Binary Counter 3 Alarm Register                           | BCNT3AR            | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C418h | RTC              | Date Alarm Register                                       | RDAYAR             | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C418h | RTC              | Binary Counter 0 Alarm Enable Register                    | BCNT0AER           | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C41Ah | RTC              | Month Alarm Register                                      | RMONAR             | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 0008 C41Ah | RTC              | Binary Counter 1 Alarm Enable Register                    | BCNT1AER           | 8                 | 8              | 2 or 3 PCLKB               | section 21               |
| 008 C41Ch  | RTC              | Year Alarm Register                                       | RYRAR              | 16                | 16             | 2 or 3 PCLKB               | section 21               |
| 008 C41Ch  | RTC              | Binary Counter 2 Alarm Enable Register                    | BCNT2AER           | 16                | 16             | 2 or 3 PCLKB               | section 21               |
| 0008 C41Eh | RTC              | Year Alarm Enable Register                                | RYRAREN            | 8                 | 8              | 2 or 3 PCLKB               | section 21               |

Table 5.1 List of I/O Registers (Address Order) (13/13)

| Address    | Module<br>Symbol | Register Name                                    | Register<br>Symbol | Number of<br>Bits | Access<br>Size | Number of Access<br>States | Reference<br>Section |
|------------|------------------|--------------------------------------------------|--------------------|-------------------|----------------|----------------------------|----------------------|
| 0008 C41Eh | RTC              | Binary Counter 3 Alarm Enable Register           | BCNT3AER           | 8                 | 8              | 2 or 3 PCLKB               | section 21.          |
| 0008 C422h | RTC              | RTC Control Register 1                           | RCR1               | 8                 | 8              | 2 or 3 PCLKB               | section 21.          |
| 0008 C424h | RTC              | RTC Control Register 2                           | RCR2               | 8                 | 8              | 2 or 3 PCLKB               | section 21.          |
| 0008 C426h | RTC              | RTC Control Register 3                           | RCR3               | 8                 | 8              | 2 or 3 PCLKB               | section 21.          |
| 0008 C42Eh | RTC              | Time Error Adjustment Register                   | RADJ               | 8                 | 8              | 2 or 3 PCLKB               | section 21.          |
| 007F C0ACh | TEMPS            | Temperature Sensor Calibration Data Register     | TSCDRL             | 8                 | 8              | 1 or 2 PCLKB               | section 28.          |
| 007F C0ADh | TEMPS            | Temperature Sensor Calibration Data Register     | TSCDRH             | 8                 | 8              | 1 or 2 PCLKB               | section 28.          |
| 007F C0B0h | FLASH            | Flash Start-Up Setting Monitor Register          | FSCMR              | 16                | 16             | 2 or 3 FCLK                | section 31.          |
| 007F C0B2h | FLASH            | Flash Access Window Start Address Monitor        | FAWSMR             | 16                | 16             | 2 or 3 FCLK                | section 31.          |
| 007F C0B4h | FLASH            | Flash Access Window End Address Monitor Register | FAWEMR             | 16                | 16             | 2 or 3 FCLK                | section 31.          |
| 007F C0B6h | FLASH            | Flash Initial Setting Register                   | FISR               | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F C0B7h | FLASH            | Flash Extra Area Control Register                | FEXCR              | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F C0B8h | FLASH            | Flash Error Address Monitor Register L           | FEAML              | 16                | 16             | 2 or 3 FCLK                | section 31.          |
| 007F C0BAh | FLASH            | Flash Error Address Monitor Register H           | FEAMH              | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F C0C0h | FLASH            | Protection Unlock Register                       | FPR                | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F C0C1h | FLASH            | Protection Unlock Status Register                | FPSR               | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F C0C2h | FLASH            | Flash Read Buffer Register L                     | FRBL               | 16                | 16             | 2 or 3 FCLK                | section 31.          |
| 007F C0C4h | FLASH            | Flash Read Buffer Register H                     | FRBH               | 16                | 16             | 2 or 3 FCLK                | section 31.          |
| 007F FF80h | FLASH            | Flash P/E Mode Control Register                  | FPMCR              | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F FF81h | FLASH            | Flash Area Select Register                       | FASR               | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F FF82h | FLASH            | Flash Processing Start Address Register L        | FSARL              | 16                | 16             | 2 or 3 FCLK                | section 31.          |
| 007F FF84h | FLASH            | Flash Processing Start Address Register H        | FSARH              | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F FF85h | FLASH            | Flash Control Register                           | FCR                | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F FF86h | FLASH            | Flash Processing End Address Register L          | FEARL              | 16                | 16             | 2 or 3 FCLK                | section 31.          |
| 007F FF88h | FLASH            | Flash Processing End Address Register H          | FEARH              | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F FF89h | FLASH            | Flash Reset Register                             | FRESETR            | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F FF8Ah | FLASH            | Flash Status Register 0                          | FSTATR0            | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F FF8Bh | FLASH            | Flash Status Register 1                          | FSTATR1            | 8                 | 8              | 2 or 3 FCLK                | section 31.          |
| 007F FF8Ch | FLASH            | Flash Write Buffer Register L                    | FWBL               | 16                | 16             | 2 or 3 FCLK                | section 31.          |
| 007F FF8Eh | FLASH            | Flash Write Buffer Register H                    | FWBH               | 16                | 16             | 2 or 3 FCLK                | section 31.          |
| 007F FFB2h | FLASH            | Flash P/E Mode Entry Register                    | FENTRYR            | 16                | 16             | 2 or 3 FCLK                | section 31.          |

Note 1. Odd addresses cannot be accessed in 16-bit units. When accessing a register in 16-bit units, access the address of the TMOCNTL register. Table 24.6 lists register allocation for 16-bit access.

## 6. Resets

#### 6.1 Overview

There are six types of resets: RES# pin reset, power-on reset, voltage monitoring 1 reset, voltage monitoring 2 reset, independent watchdog timer reset, and software reset.

Table 6.1 lists the reset names and sources.

Table 6.1 Reset Names and Sources

| Reset Name                       | Source                                                                |
|----------------------------------|-----------------------------------------------------------------------|
| RES# pin reset                   | Voltage input to the RES# pin is driven low.                          |
| Power-on reset                   | VCC rises (voltage monitored: VPOR)*1                                 |
| Voltage monitoring 1 reset       | VCC falls (voltage monitored: Vdet1)*1                                |
| Voltage monitoring 2 reset       | VCC falls (voltage monitored: Vdet2)*1                                |
| Independent watchdog timer reset | The independent watchdog timer underflows, or a refresh error occurs. |
| Software reset                   | Register setting                                                      |

Note 1. For details on the voltages to be monitored (VPOR, Vdet1, and Vdet2), refer to section 8, Voltage Detection Circuit (LVDAa) and section 32, Electrical Characteristics.

The internal state and pins are initialized by a reset.

Table 6.2 lists the reset targets to be initialized.

Table 6.2 Targets Initialized According to Reset Source

|                                                                                                                    | Reset Source   |                   |                                        |                                  |                                  |                   |
|--------------------------------------------------------------------------------------------------------------------|----------------|-------------------|----------------------------------------|----------------------------------|----------------------------------|-------------------|
| Target to be Initialized                                                                                           | RES# Pin Reset | Power-On<br>Reset | Independent<br>Watchdog<br>Timer Reset | Voltage<br>Monitoring 1<br>Reset | Voltage<br>Monitoring 2<br>Reset | Software<br>Reset |
| Power-on reset detect flag (RSTSR0.PORF)                                                                           | 0              | _                 | _                                      | _                                | _                                | _                 |
| Register related to the cold start/warm start determination flag (RSTSR1.CWSF)                                     | *1             | 0                 | _                                      | _                                | _                                | _                 |
| Independent watchdog timer reset detect flag (RSTSR2.IWDTRF)                                                       | 0              | 0                 | _                                      | _                                | _                                | _                 |
| Registers related to the independent watchdog timer (IWDTRR, IWDTCR, IWDTSR, IWDTRCR, IWDTRCR, IWDTCSTPR, ILOCOCR) | 0              | 0                 | _                                      | _                                | _                                | _                 |
| Voltage monitoring 1 reset detect flag (RSTSR0.LVD1RF)                                                             | 0              | 0                 | 0                                      | _                                | _                                | _                 |
| Registers related to the voltage monitor function 1 (LVD1CR0, LVCMPCR.LVD1E, LVDLVLR.LVD1LVL[3:0])                 | 0              | 0                 | ٥                                      | _                                | _                                | _                 |
| (LVD1CR1, LVD1SR)                                                                                                  | 0              | 0                 | 0                                      | _                                | _                                | _                 |
| Voltage monitoring 2 reset detect flag (RSTSR0.LVD2RF)                                                             | 0              | 0                 | 0                                      | 0                                | _                                | _                 |
| Registers related to the voltage monitor function 2 (LVD2CR0, EXVCCINP2, LVCMPCR.LVD2E, LVDLVLR.LVD2LVL[1:0])      | 0              | 0                 | 0                                      | 0                                | _                                | _                 |
| (LVD2CR1, LVD2SR)                                                                                                  | 0              | 0                 | 0                                      | 0                                |                                  |                   |
| Software reset detect flag (RSTSR2.SWRF)                                                                           | 0              | 0                 | 0                                      | 0                                | 0                                | _                 |
| Registers related to the realtime clock*2                                                                          | _              | _                 | _                                      | _                                | _                                | _                 |
| Registers other than the above, the CPU, and internal state                                                        | 0              | 0                 | 0                                      | 0                                | 0                                | 0                 |

o: Targets to be initialized, —: No change occurs.

When a reset is canceled, the reset exception handling starts. For details on the reset exception handling, refer to section 13, Exception Handling.

Table 6.3 lists the pin related to the reset.

Table 6.3 Pin Related to Reset

| Pin Name | I/O   | Function  |
|----------|-------|-----------|
| RES#     | Input | Reset pin |

Note 1. Initialized at a power-on.

Note 2. Some control bits (RCR1.CIE, RCR1.RTCOS, RCR2.RTCOE, ADJ30, and RESET) are initialized by all types of resets. For details on the target bits, refer to section 21, Realtime Clock (RTCA).

#### 6.2 Register Descriptions

#### 6.2.1 Reset Status Register 0 (RSTSR0)

Address(es): 0008 C290h



Note 1. The value after reset depends on the reset source.

| Bit      | Symbol | Bit Name                                  | Description                                                                       | R/W         |
|----------|--------|-------------------------------------------|-----------------------------------------------------------------------------------|-------------|
| b0       | PORF   | Power-On Reset Detect Flag                | O: Power-on reset not detected.  1: Power-on reset detected.                      | R/(W)<br>*1 |
| b1       | _      | Reserved                                  | This bit is read as 0. The write value should be 0.                               | R/W         |
| b2       | LVD1RF | Voltage Monitoring 1 Reset Detect<br>Flag | Voltage monitoring 1 reset not detected.     Voltage monitoring 1 reset detected. | R/(W)<br>*1 |
| b3       | LVD2RF | Voltage Monitoring 2 Reset Detect Flag    | Voltage monitoring 2 reset not detected.     Voltage monitoring 2 reset detected. | R/(W)<br>*1 |
| b7 to b4 | _      | Reserved                                  | These bits are read as 0. The write value should be 0.                            | R/W         |

Note 1. Only 0 can be written to clear the flag.

#### PORF Flag (Power-On Reset Detect Flag)

The PORF flag indicates that a power-on reset has occurred.

[Setting condition]

• When a power-on reset occurs.

[Clearing conditions]

- When a reset shown in Table 6.2 occurs.
- When PORF is read as 1 and then 0 is written to PORF.

#### LVD1RF Flag (Voltage Monitoring 1 Reset Detect Flag)

The LVD1RF flag indicates that VCC voltage has fallen below Vdet1.

[Setting condition]

• When Vdet1-level VCC voltage is detected.

[Clearing conditions]

- When a reset listed in Table 6.2 occurs.
- When LVD1RF is read as 1 and then 0 is written to LVD1RF.

#### LVD2RF Flag (Voltage Monitoring 2 Reset Detect Flag)

The LVD2RF flag indicates that VCC voltage has fallen below Vdet2. [Setting condition]

• When Vdet2-level VCC voltage is detected.

[Clearing conditions]

- When a reset listed in Table 6.2 occurs.
- When LVD2RF is read as 1 and then 0 is written to LVD2RF.

# 6.2.2 Reset Status Register 1 (RSTSR1)

Address(es): 0008 C291h



Note 1. The value after reset depends on the reset source.

| Bit      | Symbol | Bit Name                           | Description                                            | R/W         |
|----------|--------|------------------------------------|--------------------------------------------------------|-------------|
| b0       | CWSF   | Cold/Warm Start Determination Flag | 0: Cold start<br>1: Warm start                         | R/(W)<br>*1 |
| b7 to b1 | _      | Reserved                           | These bits are read as 0. The write value should be 0. | R/W         |

Note 1. Only 1 can be written to set the flag.

RSTSR1 determines whether a power-on reset has caused the reset processing (cold start) or a reset signal input during operation has caused the reset processing (warm start).

#### **CWSF Flag (Cold/Warm Start Determination Flag)**

The CWSF flag indicates the type of reset processing: cold start or warm start.

The CWSF flag is initialized at a power-on.

[Setting condition]

• When 1 is written through programming; it is not set to 0 even when 0 is written.

[Clearing condition]

• When a reset listed in Table 6.2 occurs.

# 6.2.3 Reset Status Register 2 (RSTSR2)

Address(es): 0008 00C0h



Note 1. The value after reset depends on the reset source.

| Bit      | Symbol | Bit Name                                     | Description                                                                                   | R/W         |
|----------|--------|----------------------------------------------|-----------------------------------------------------------------------------------------------|-------------|
| b0       | IWDTRF | Independent Watchdog Timer Reset Detect Flag | Independent watchdog timer reset not detected.     Independent watchdog timer reset detected. | R/(W)<br>*1 |
| b1       | _      | Reserved                                     | This bit is read as 0. The write value should be 0.                                           | R/W         |
| b2       | SWRF   | Software Reset Detect Flag                   | Software reset not detected.     Software reset detected.                                     | R/(W)<br>*1 |
| b7 to b3 | _      | Reserved                                     | These bits are read as 0. The write value should be 0.                                        | R/W         |

Note 1. Only 0 can be written to clear the flag.

#### **IWDTRF Flag (Independent Watchdog Timer Reset Detect Flag)**

The IWDTRF flag indicates that an independent watchdog timer reset has occurred. [Setting condition]

• When an independent watchdog timer reset occurs.

[Clearing conditions]

- When a reset listed in Table 6.2 occurs.
- When IWDTRF is read as 1 and then 0 is written to IWDTRF.

#### **SWRF Flag (Software Reset Detect Flag)**

The SWRF flag indicates that a software reset has occurred. [Setting condition]

• When a software reset occurs.

[Clearing conditions]

- When a reset listed in Table 6.2 occurs.
- When SWRF is read as 1 and then 0 is written to SWRF.

# 6.2.4 Software Reset Register (SWRR)

Address(es): 0008 00C2h



| Bit       | Symbol     | Bit Name       | Description                                                 | R/W |
|-----------|------------|----------------|-------------------------------------------------------------|-----|
| b15 to b0 | SWRR[15:0] | Software Reset | Writing A501h resets the MCU. These bits are read as 0000h. | R/W |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

## 6.3 Operation

#### 6.3.1 RES# Pin Reset

This is a reset generated by the RES# pin.

When the RES# pin is driven low, all the processing in progress is aborted and the MCU enters a reset state.

To ensure the MCU is reset, the RES# pin should be held low for the specified power supply stabilization time at a power-on.

When the RES# pin is driven high from low, the internal reset is canceled after the RES# post-cancelation wait time (tRESWT) has elapsed, and then the CPU starts the reset exception handling.

For details, refer to section 32, Electrical Characteristics.

#### 6.3.2 Power-On Reset

The power-on reset is an internal reset generated by the power-on reset circuit.

A power-on reset is generated when power is supplied to the RES# pin while it is connected to VCC via a resistor. When connecting a capacitor to the RES# pin, also ensure that the voltage on the RES# pin is always at least VIH. For details on VIH, refer to section 32, Electrical Characteristics. After VCC has exceeded VPOR and the specified period (power-on reset time) has elapsed, the internal reset is canceled and the CPU starts the reset exception handling. The power-on reset time is a stabilization period for the external power supply and the MCU circuit. After a power-on reset has been generated, the RSTSR0.PORF flag is set to 1. The PORF flag is initialized by a RES# pin reset.

Figure 6.1 shows an example of the power-on reset circuit and its operation.



Figure 6.1 Operation Examples during Power-On Reset

### 6.3.3 Voltage Monitoring 1 Reset and Voltage Monitoring 2 Reset

The voltage monitoring 1 reset and voltage monitoring 2 reset are internal resets generated by the voltage monitoring circuit.

When the voltage monitoring 1 interrupt/reset enable bit (LVD1RIE) is set to 1 (enabled) and the voltage monitoring 1 circuit mode select bit (LVD1RI) is set to 1 (voltage monitoring 1 reset enabled when the voltage falls to and below Vdet1) in voltage monitoring 1 circuit control register 0 (LVD1CR0), the RSTSR0.LVD1RF flag is set to 1 and the voltage-detection circuit generates a voltage monitoring 1 reset if VCC falls to or below Vdet1.

Likewise, when the voltage monitoring 2 interrupt/reset enable bit (LVD2RIE) is set to 1 (enabled) and the voltage monitoring 2 circuit mode select bit (LVD2RI) is set to 1 (voltage monitoring 2 reset enabled when the voltage falls to and below Vdet2) in voltage monitoring 2 circuit control register 0 (LVD2CR0), the RSTSR0.LVD2RF flag is set to 1 and the voltage detection circuit generates a voltage monitoring 2 reset if VCC falls to or below Vdet2.

Timing for release from the voltage monitoring 1 reset state is selectable with the voltage monitoring 1 reset negate select bit (LVD1RN) in the LVD1CR0 register. When the LVD1CR0.LVD1RN bit is 0 and VCC has fallen to or below Vdet1, the CPU is released from the internal reset state and starts reset exception handling once the LVD1 reset time (tLVD1) has elapsed after VCC has risen above Vdet1. When the LVD1CR0.LVD1RN bit is 1 and VCC has fallen to or below Vdet1, the CPU is released from the internal reset state and starts reset exception handling once the LVD1 reset time (tLVD1) has elapsed.

Likewise, timing for release from the voltage monitoring 2 reset state is selectable by setting the voltage monitoring 2 reset negate select bit (LVD2RN) in the LVD2CR0 register. Detection levels Vdet1 and Vdet2 can be changed by settings in the voltage detection level select register (LVDLVLR).

Figure 6.2 shows examples of operations during voltage monitoring 1 and 2 resets.

For details on the voltage monitoring 1 reset and voltage monitoring 2 reset, refer to section 8, Voltage Detection Circuit (LVDAa).





Figure 6.2 Operation Examples during Voltage Monitoring 1 Reset and Voltage Monitoring 2 Reset

## 6.3.4 Independent Watchdog Timer Reset

The independent watchdog timer reset is an internal reset generated by the independent watchdog timer.

Enabling and disabling output of the independent watchdog timer reset from the independent watchdog timer can be selected by setting the IWDT reset control register (IWDTRCR) and option function select register 0 (OFS0).

When output of the independent watchdog timer reset is enabled, an independent watchdog timer reset is generated if the independent watchdog timer underflows, or if data is written outside the refresh-permitted period. After the independent watchdog timer reset has been generated and the internal reset time (tRESW2) has elapsed, the internal reset is canceled and the CPU starts the reset exception handling.

For details on the independent watchdog timer reset, refer to section 22, Independent Watchdog Timer (IWDTa).

### 6.3.5 Software Reset

The software reset is an internal reset generated by the software reset circuit.

A software reset is generated when A501h is written to the SWRR register. After the software reset has been generated and tRESW2 has elapsed, the internal reset is canceled and the CPU starts the reset exception handling.

### 6.3.6 Determination of Cold/Warm Start

By reading the RSTSR1.CWSF flag, the type of reset processing caused can be identified; that is, whether a power-on reset has caused the reset processing (cold start) or a reset signal input during operation has caused the reset processing (warm start).

The RSTSR1.CWSF flag is set to 0 when a power-on reset occurs (cold start); otherwise the flag is not set to 0. The flag is set to 1 when 1 is written to it through programming; it is not set to 0 even when 0 is written.

Figure 6.3 shows an example of cold/warm start determination operation.



Figure 6.3 Example of Cold/Warm Start Determination Operation

### 6.3.7 Determination of Reset Generation Source

Reading the RSTSR0 and RSTSR2 registers determines which reset was used to execute the reset exception handling. Figure 6.4 shows an example of the flow to identify a reset generation source.



Figure 6.4 Example of Reset Generation Source Determination Flow

# 7. Option-Setting Memory

### 7.1 Overview

Option-setting memory refers to a set of registers that are provided for selecting the state of the microcontroller after a reset. The option-setting memory is allocated in the ROM.

Figure 7.1 shows the option-setting memory area.



Figure 7.1 Option-Setting Memory Area

## 7.2 Register Descriptions

## 7.2.1 Option Function Select Register 0 (OFS0)

Address(es): FFFF FF8Ch b31 b30 b29 b28 b27 b26 b25 b24 b23 b22 b21 b20 b19 b17 b16 b18 Value after reset: The value set by the user\*1 b15 b14 b13 b12 b11 b10 b9 b8 b7 b5 b4 b3 b1 b0 IWDTS LCSTP IWDTR STIRQS **IWDTS** IWDTRPSS[1:0] IWDTRPES[1:0] IWDTCKS[3:0] IWDTTOPS[1:0] Value after reset: The value set by the user\*1

Note 1. The value of the blank product is FFFF FFFFh. It is set to the written value after written by the user.

| Bit        | Symbol        | Bit Name                                      | Description                                                                                                                                                                                                                                                                        | R/W |
|------------|---------------|-----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0         | _             | Reserved                                      | When reading, this bit returns the value written by the user. The write value should be 1.                                                                                                                                                                                         | R   |
| b1         | IWDTSTRT      | IWDT Start Mode<br>Select                     | 0: IWDT is automatically activated in auto-start mode after a reset 1: IWDT is halted after a reset                                                                                                                                                                                | R   |
| b3, b2     | IWDTTOPS[1:0] | IWDT Timeout Period<br>Select                 | b3 b2<br>0 0: 128 cycles (007Fh)<br>0 1: 512 cycles (01FFh)<br>1 0: 1024 cycles (03FFh)<br>1 1: 2048 cycles (07FFh)                                                                                                                                                                | R   |
| b7 to b4   | IWDTCKS[3:0]  | IWDT Clock Frequency<br>Division Ratio Select | b7 b4 0 0 0 0: x1 (Cycle period: 136 ms) 0 0 1 0: x1/16 (Cycle period: 2.18 s) 0 0 1 1: x1/32 (Cycle period: 4.36 s) 0 1 0 0: x1/64 (Cycle period: 8.73 s) 1 1 1 1: x1/128 (Cycle period: 17.5 s) 0 1 0 1: x1/256 (Cycle period: 34.9 s) Settings other than above are prohibited. | R   |
| b9, b8     | IWDTRPES[1:0] | IWDT Window End<br>Position Select            | b9 b8<br>0 0: 75%<br>0 1: 50%<br>1 0: 25%<br>1 1: 0% (No window end position setting)                                                                                                                                                                                              | R   |
| b11, b10   | IWDTRPSS[1:0] | IWDT Window Start<br>Position Select          | b11 b10<br>0 0: 25%<br>0 1: 50%<br>1 0: 75%<br>1 1: 100% (No window start position setting)                                                                                                                                                                                        | R   |
| b12        | IWDTRSTIRQS   | IWDT Reset Interrupt<br>Request Select        | Non-maskable interrupt request is enabled     Reset is enabled                                                                                                                                                                                                                     | R   |
| b13        | _             | Reserved                                      | When reading, this bit returns the value written by the user. The write value should be 1.                                                                                                                                                                                         | R   |
| b14        | IWDTSLCSTP    | IWDT Sleep Mode<br>Count Stop Control         | Counting stop is disabled     Counting stop is enabled when entering sleep, software standby mode, and deep sleep mode                                                                                                                                                             | R   |
| b31 to b15 | _             | Reserved                                      | When reading, these bits return the value written by the user. The write value should be 1.                                                                                                                                                                                        | R   |

The OFS0 register selects the operations of the independent watchdog timer (IWDT) after a reset.

The OFS0 register is allocated in the ROM. Set this register at the same time as writing the program. After writing to the OFS0 register once, do not write to it again.

When erasing the block including the OFS0 register, the OFS0 register value becomes FFFF FFFFh.

The setting in the OFS0 register is ineffective in boot mode.

#### **IWDTSTRT Bit (IWDT Start Mode Select)**

This bit selects the mode in which the IWDT is activated after a reset (stopped state or activated in auto-start mode). When activated in auto-start mode, the OFS0 register setting for the IWDT is effective.

#### IWDTTOPS[1:0] Bits (IWDT Timeout Period Select)

These bits select the timeout period, i.e. the time it takes for the down-counter to underflow, as 128, 512, 1024, or 2048 cycles of the frequency-divided clock set by the IWDTCKS[3:0] bits. The time (number of clock cycles for the IWDT) it takes to underflow after a refresh operation is determined by the combination of the IWDTCKS[3:0] bits and IWDTTOPS[1:0] bits.

For details, refer to section 22, Independent Watchdog Timer (IWDTa).

#### IWDTCKS[3:0] Bits (IWDT Clock Frequency Division Ratio Select)

These bits select, from 1/1, 1/16, 1/32, 1/64, 1/128, and 1/256, the division ratio of the prescaler to divide the frequency of the clock for the IWDT. Using the setting of these bits together with the IWDTTOPS[1:0] bit setting, the IWDT counting period can be set from 128 to 524288 clock cycles for the IWDT.

For details, refer to section 22, Independent Watchdog Timer (IWDTa).

#### IWDTRPES[1:0] Bits (IWDT Window End Position Select)

These bits select the position of the end of the window for the down-counter as 0%, 25%, 50%, or 75% of the value being counted by the counter. The value of the window end position must be smaller than the value of the window start position (window start position > window end position). If the value for the window end position is greater than the value for the window start position, only the value for the window start position is effective.

The counter values corresponding to the settings for the start and end positions of the window in the IWDTRPSS[1:0] and IWDTRPES[1:0] bits vary with the setting of the IWDTTOPS[1:0] bits.

For details, refer to section 22, Independent Watchdog Timer (IWDTa).

#### IWDTRPSS[1:0] Bits (IWDT Window Start Position Select)

These bits select the position where the window for the down-counter starts as 25%, 50%, 75%, or 100% of the value being counted (the point at which counting starts is 100% and the point at which an underflow occurs is 0%). The interval between the positions where the window starts and ends becomes the period in which refreshing is possible, and refreshing is not possible outside this period.

For details, refer to section 22, Independent Watchdog Timer (IWDTa).

#### IWDTRSTIRQS Bit (IWDT Reset Interrupt Request Select)

The setting of this bit selects the operation on an underflow of the down-counter or generation of a refresh error. Either an independent watchdog timer reset or a non-maskable interrupt request is selectable.

For details, refer to section 22, Independent Watchdog Timer (IWDTa).

#### **IWDTSLCSTP Bit (IWDT Sleep Mode Count Stop Control)**

This bit selects to stop counting when entering sleep, software standby mode, and deep sleep mode.

For details, refer to section 22, Independent Watchdog Timer (IWDTa).



Value after reset

b31 to b9

## 7.2.2 Option Function Select Register 1 (OFS1)

Address(es): FFFF FF88h b31 b30 b29 b28 b27 b26 b25 b24 b23 b22 b21 b20 b19 b18 b17 b16 Value after reset: The value set by the user\*1 b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0 FASTS носо STUPLV STUPLVD1LVL[3:0] TUP ΕN D1REN

The value set by the user\*1

Note 1. The value of the blank product is FFFF FFFFh. It is set to the written value after written by the user.

Bit Symbol Bit Name Description R/W b0 **FASTSTUP** Power-On Fast Startup Time 0: Fast startup time at power on R 1: Normal startup b1 STUPLVD1REN Startup Voltage Monitoring 1 0: Voltage monitoring 1 reset is enabled at startup\*2 R 1: Voltage monitoring 1 reset is disabled at startup Reset Enable b3, b2 Reserved When reading, these bits return the value written by the R user. The write value should be 1. b7 to b4 STUPLVD1LVL[3:0] R Startup Voltage Monitoring 1 0 1 0 0: 3.10 V Reset Detection Level Select 0 1 0 1: 3.00 V 0 1 1 0: 2.90 V 0 1 1 1: 2.79 V 1 0 0 0: 2.68 V 1 0 0 1: 2.58 V 1 0 1 0: 2.48 V 1 0 1 1: 2.06 V 1 1 0 0: 1.96 V 1 1 0 1: 1.86 V Settings other than above are prohibited when the STUPLVD1REN bit is 0. HOCOEN hß **HOCO Oscillation Enable** 0: HOCO oscillation is enabled after a reset R 1: HOCO oscillation is disabled after a reset

Note 2. When enabling the startup voltage monitoring 1 reset and setting the reset output of the independent watchdog timer, enable the voltage monitoring 1 reset by programming immediately after a reset.

For details, refer to section 7.3.2, Note on Parallel Use of the Voltage Monitoring 1 Reset and IWDT Reset.

When reading, these bits return the value written by the

user. The write value should be 1.

The OFS1 register is allocated in the ROM. Set this register at the same time as writing the program. After writing, do not write additions to this register.

When erasing the block including the OFS1 register, the setting in the OFS1 register is ineffective, and the OFS1 register value becomes FFFF FFFFh.

The setting in the OFS1 register is ineffective in boot mode.

Reserved

R

#### **FASTSTUP Bit (Power-On Fast Startup Time)**

The startup time can be reduced by setting this bit to 0 (fast startup time at power on) when it is possible to meet the power-on VCC rising gradient (during fast startup time) shown in Electrical Characteristics.

Do not set this bit to 0 when it is not possible to meet the power-on VCC rising gradient (during fast startup time).

## STUPLVD1REN Bit (Startup Voltage Monitoring 1 Reset Enable)

This bit selects whether the voltage monitoring 1 reset is enabled or disabled after a reset.

The Vdet1 voltage to be monitored by the voltage detection 1 circuit is selected by the STUPLVD1LVL[3:0] bits.

When this bit is set to 0 (voltage monitoring 1 reset is enabled at startup) and the power is turned on, the power-on VCC rising gradient specification is the power-on VCC rising gradient (when voltage monitoring 1 reset is enabled at startup) shown in section 32, Electrical Characteristics, and there is no specified maximum value.

When the STUPLVD1REN bit is set to 0, the MCU starts up with voltage monitoring 1 reset enabled, regardless of the FASTSTUP bit setting.

#### STUPLVD1LVL[3:0] Bits (Startup Voltage Monitoring 1 Reset Detection Level Select)

These bits select the voltage detection level to be monitored by the voltage detection 1 circuit when the STUPLVD1REN bit is set to 0.

#### **HOCOEN Bit (HOCO Oscillation Enable)**

This bit selects whether the HOCO oscillation enable bit is enabled or disabled after a reset.

Setting the HOCOEN bit to 0 allows the HOCO oscillation to be started before the CPU starts operation, and therefore reduces the waiting time for oscillation stabilization.

Note that even if the HOCOEN bit is set to 0, the system clock source is not switched to HOCO. The system clock source is switched to HOCO only by modifying the clock source select bits (SCKCR3.CKSEL[2:0]) from the CPU.

Also, when the OFS1.HOCOEN bit is set to 0, the HOCO oscillation stabilization time (tHOCO) is secured by hardware, so the clock with the accuracy of the HOCO oscillation frequency (fHOCO) shown in Electrical Characteristics is supplied after release from the CPU reset state.



## 7.2.3 Endian Select Register (MDE)

Address(es): FFFF FF80h: MDE (in single-chip mode)



Value after reset:

The value set by the user\*1

Note 1. The value of the blank product is FFFF FFFFh. It is set to the written value after written by the user.

| Bit       | Symbol   | Bit Name      | Description                                                                                     | R/W |
|-----------|----------|---------------|-------------------------------------------------------------------------------------------------|-----|
| b2 to b0  | MDE[2:0] | Endian Select | b2 b0<br>0 0 0: Big endian<br>1 1 1: Little endian<br>Settings other than above are prohibited. | R   |
| b31 to b3 | _        | Reserved      | When reading, these bits return the value written by the user. The write value should be 1.     | R   |

The MDE register selects the endian for the CPU. The endian select register (MDE) at address FFFF FF80h is used to select the endian.

MDE is allocated in the ROM. Set the register at the same time as writing the program. After writing to the register once, do not write to it again.

When erasing the block including the MDE register, the MDE register value becomes FFFF FFFFh.

## MDE[2:0] Bits (Endian Select)

These bits select little endian or big endian for the CPU.

## 7.3 Usage Note

## 7.3.1 Setting Example of Option-Setting Memory

Since the option-setting memory is allocated in the ROM, values cannot be written by executing instructions. Write appropriate values when writing the program. An example of the settings is shown below.

 To set ffff fff8h in the OFS0 register .org 0ffff ff8ch
 .lword 0ffffff8h

Note: Programming formats vary depending on the compiler. Refer to the compiler manual for details.

## 7.3.2 Note on Parallel Use of the Voltage Monitoring 1 Reset and IWDT Reset

When the OFS.STUPLVD1REN bit is set to 0 (the voltage monitoring 1 reset is enabled at startup) and the OFS0.IWDTRSTIRQS or IWDTRCR.RSTIRQS bit is set to 1 (the IWDT reset output is enabled), enable the voltage monitoring 1 reset at the beginning of the program according to the procedure in section 8.4, Interrupt and Reset from Voltage Monitoring 1.



# 8. Voltage Detection Circuit (LVDAa)

The voltage detection circuit (LVD) monitors the voltage level input to the VCC pin using a program.

## 8.1 Overview

In voltage detection 1, the detection voltage can be selected from 10 levels using the voltage detection level select register (LVDLVLR).

In voltage detection 2, the detection voltage can be selected from four levels by switching between input voltages to VCC and the CMPA2 pin.

Reset/interrupt of voltage monitoring 1, and reset/interrupt of voltage monitoring 2 can be used.

Table 8.1 lists the specifications of the voltage detection circuit. Figure 8.1 is a block diagram of the voltage detection circuit. Figure 8.2 is a block diagram of the voltage monitoring 1 interrupt/reset circuit. Figure 8.3 is a block diagram of the voltage monitoring 2 interrupt/reset circuit.

Table 8.1 LVD Specifications

| Item              |                   | Voltage Monitoring 1                                                                                       | Voltage Monitoring 2                                                                                                                                                                             |
|-------------------|-------------------|------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VCC monitoring    | Monitored voltage | Vdet1                                                                                                      | Vdet2                                                                                                                                                                                            |
|                   | Detection         | When voltage rises above or drops below Vdet1                                                              | When voltage rises above or drops below Vdet2                                                                                                                                                    |
|                   | target            |                                                                                                            | Input voltages to VCC and the CMPA2 pin can be switched using the LVCMPCR.EXVCCINP2 bit                                                                                                          |
|                   | Detection voltage | Voltage selectable from 10 levels using the LVDLVLR.LVD1LVL[3:0] bits                                      | Voltage selectable from four levels using the LVDLVLR.LVD2LVL[1:0] bits                                                                                                                          |
|                   | Monitoring flag   | LVD1SR.LVD1MON flag: Monitors whether voltage is higher or lower than Vdet1                                | LVD2SR.LVD2MON flag: Monitors whether voltage is higher or lower than Vdet2                                                                                                                      |
|                   |                   | LVD1SR.LVD1DET flag: Vdet1 passage detection                                                               | LVD2SR.LVD2DET flag: Vdet2 passage detection                                                                                                                                                     |
| Process upon      | Reset             | Voltage monitoring 1 reset                                                                                 | Voltage monitoring 2 reset                                                                                                                                                                       |
| voltage detection |                   | Reset when Vdet1 > VCC CPU restart timing selectable: after specified time with VCC > Vdet1 or Vdet1 > VCC | Reset when Vdet2 > VCC or the CMPA2 pin<br>CPU restart timing selectable: after specified time<br>with VCC or the CMPA2 pin > Vdet2 or after<br>specified time with Vdet2 > VCC or the CMPA2 pin |
|                   | Interrupt         | Voltage monitoring 1 interrupt                                                                             | Voltage monitoring 2 interrupt                                                                                                                                                                   |
|                   |                   | Non-maskable or maskable interrupt is selectable                                                           | Non-maskable or maskable interrupt is selectable                                                                                                                                                 |
|                   |                   | Interrupt request issued when Vdet1 > VCC and VCC > Vdet1 or either                                        | Interrupt request issued when Vdet2 > VCC or the CMPA2 pin and VCC or the CMPA2 pin > Vdet2 or either                                                                                            |



Figure 8.1 Block Diagram of the LVD



Figure 8.2 Block Diagram of Voltage Monitoring 1 Interrupt/Reset Circuit



Figure 8.3 Block Diagram of Voltage Monitoring 2 Interrupt/Reset Circuit

Table 8.2 lists the I/O pins relevant to the voltage detection circuit.

Table 8.2 I/O Pins of the Voltage Detection Circuit

| Pin Name | I/O   | Function                                             |
|----------|-------|------------------------------------------------------|
| CMPA2    | Input | Detection target voltage pin for voltage detection 2 |

# 8.2 Register Descriptions

# 8.2.1 Voltage Monitoring 1 Circuit Control Register 1 (LVD1CR1)

Address(es): 0008 00E0h



| Bit      | Symbol              | Bit Name                                                      | Description                                                                                                                                          | R/W |
|----------|---------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1, b0   | LVD1IDTSEL<br>[1:0] | Voltage Monitoring 1 Interrupt<br>Generation Condition Select | b1 b0 0 0: When VCC ≥ Vdet1 (rise) is detected 0 1: When VCC < Vdet1 (drop) is detected 1 0: When drop and rise are detected 1 1: Setting prohibited | R/W |
| b2       | LVD1IRQSEL          | Voltage Monitoring 1 Interrupt Type Select                    | 0: Non-maskable interrupt 1: Maskable interrupt                                                                                                      | R/W |
| b7 to b3 | _                   | Reserved                                                      | These bits are read as 0. The write value should be 0.                                                                                               | R/W |

Note: Set the PRCR.PRC3 bit to 1 (write enabled) before rewriting this register.

## 8.2.2 Voltage Monitoring 1 Circuit Status Register (LVD1SR)

Address(es): 0008 00E1h



| Bit      | Symbol  | Bit Name                                              | Description                                                     | R/W         |
|----------|---------|-------------------------------------------------------|-----------------------------------------------------------------|-------------|
| b0       | LVD1DET | Voltage Monitoring 1 Voltage Change<br>Detection Flag | 0: Not detected 1: Vdet1 passage detection                      | R/(W)<br>*1 |
| b1       | LVD1MON | Voltage Monitoring 1 Signal Monitor Flag              | 0: VCC < Vdet1<br>1: VCC ≥ Vdet1 or LVD1MON circuit is disabled | R           |
| b7 to b2 | _       | Reserved                                              | These bits are read as 0. The write value should be 0.          | R/W         |

Note: Set the PRCR.PRC3 bit to 1 (write enabled) before rewriting this register.

Note 1. Only 0 can be written to this bit. After writing 0 to this bit, it takes two system clock cycles for the bit to be read as 0.

### LVD1DET Flag (Voltage Monitoring 1 Voltage Change Detection Flag)

The LVD1DET flag is enabled when the LVCMPCR.LVD1E bit is 1 (voltage detection 1 circuit enabled) and the LVD1CR0.LVD1CMPE bit is 1 (voltage monitoring 1 circuit comparison result output enabled).

The LVD1DET flag should be set to 0 after LVD1CR0.LVD1RIE is set to 0 (disabled). LVD1CR0.LVD1RIE can be set to 1 (enabled) again after a period of two or more cycles of PCLKB has elapsed.

Depending on the number of cycles of PCLKB defined for access to read an I/O register, two or more cycles of PCLKB may have to be secured as waiting time.

### LVD1MON Flag (Voltage Monitoring 1 Signal Monitor Flag)

The LVD1MON flag is enabled when the LVCMPCR.LVD1E bit is 1 (voltage detection 1 circuit enabled) and the LVD1CR0.LVD1CMPE bit is 1 (voltage monitoring 1 circuit comparison result output enabled).

# 8.2.3 Voltage Monitoring 2 Circuit Control Register 1 (LVD2CR1)

Address(es): 0008 00E2h



| Bit      | Symbol              | Bit Name                                                      | Description                                                                                                                                                                                                                                       | R/W |
|----------|---------------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1, b0   | LVD2IDTSEL<br>[1:0] | Voltage Monitoring 2 Interrupt<br>Generation Condition Select | <ul> <li>b1 b0</li> <li>0 0: When VCC or the CMPA2 pin ≥ Vdet2 (rise) is detected</li> <li>0 1: When VCC or the CMPA2 pin &lt; Vdet2 (drop) is detected</li> <li>1 0: When drop and rise are detected</li> <li>1 1: Setting prohibited</li> </ul> | R/W |
| b2       | LVD2IRQSEL          | Voltage Monitoring 2 Interrupt Type<br>Select                 | 0: Non-maskable interrupt<br>1: Maskable interrupt                                                                                                                                                                                                | R/W |
| b7 to b3 | _                   | Reserved                                                      | These bits are read as 0. The write value should be 0.                                                                                                                                                                                            | R/W |

Note: Set the PRCR.PRC3 bit to 1 (write enabled) before rewriting this register.

## 8.2.4 Voltage Monitoring 2 Circuit Status Register (LVD2SR)

Address(es): 0008 00E3h



| Bit      | Symbol  | Bit Name                                              | Description                                                                            | R/W         |
|----------|---------|-------------------------------------------------------|----------------------------------------------------------------------------------------|-------------|
| b0       | LVD2DET | Voltage Monitoring 2 Voltage Change<br>Detection Flag | 0: Not detected<br>1: Vdet2 passage detection                                          | R/(W)<br>*1 |
| b1       | LVD2MON | Voltage Monitoring 2 Signal Monitor Flag              | 0: VCC or the CMPA2 pin < Vdet2 1: VCC or the CMPA2 pin ≥ Vdet2 or LVD2MON is disabled | R           |
| b7 to b2 | _       | Reserved                                              | These bits are read as 0. The write value should be 0.                                 | R/W         |

Note: Set the PRCR.PRC3 bit to 1 (write enabled) before rewriting this register.

Note 1. Only 0 can be written to this bit. After writing 0 to this bit, it takes two system clock cycles for the bit to be read as 0.

## LVD2DET Flag (Voltage Monitoring 2 Voltage Change Detection Flag)

The LVD2DET flag is enabled when the LVCMPCR.LVD2E bit is 1 (voltage detection 2 circuit enabled) and the LVD2CR0.LVD2CMPE bit is 1 (voltage monitoring 2 circuit comparison result output enabled).

The LVD2DET flag should be set to 0 after LVD2CR0.LVD2RIE is set to 0 (disabled). LVD2CR0.LVD2RIE can be set to 1 (enabled) again after a period of two or more cycles of PCLKB has elapsed.

Depending on the number of cycles of PCLKB defined for access to read an I/O register, two or more cycles of PCLKB may have to be secured as waiting time.

#### LVD2MON Flag (Voltage Monitoring 2 Signal Monitor Flag)

The LVD2MON flag is enabled when the LVCMPCR.LVD2E bit is 1 (voltage detection 2 circuit enabled) and the LVD2CR0.LVD2CMPE bit is 1 (voltage monitoring 2 circuit comparison result output enabled).

## 8.2.5 Voltage Monitoring Circuit Control Register (LVCMPCR)

Address(es): 0008 C297h



Note 1. The value after a reset is 1 when the OSF1.STUPLVD1REN bit is 0.

| Bit      | Symbol    | Bit Name                                                           | Description                                                                  | R/W |
|----------|-----------|--------------------------------------------------------------------|------------------------------------------------------------------------------|-----|
| b2 to b0 | _         | Reserved                                                           | These bits are read as 0. The write value should be 0.                       | R/W |
| b3       | EXVCCINP2 | Voltage Detection 2 Comparison<br>Voltage External Input Select *1 | Power supply voltage (VCC)     CMPA2 pin input voltage                       | R/W |
| b4       | _         | Reserved                                                           | This bit is read as 0. The write value should be 0.                          | R/W |
| b5       | LVD1E     | Voltage Detection 1 Enable                                         | Voltage detection 1 circuit disabled     Voltage detection 1 circuit enabled | R/W |
| b6       | LVD2E     | Voltage Detection 2 Enable                                         | Voltage detection 2 circuit disabled     Voltage detection 2 circuit enabled | R/W |
| b7       | _         | Reserved                                                           | This bit is read as 0. The write value should be 0.                          | R/W |

Note: Set the PRCR.PRC3 bit to 1 (write enabled) before rewriting this register.

Note 1. The EXVCCINP2 bit can be changed only when the LVD1E and LVD2E bits are both 0 (voltage detection 1 circuit and voltage detection 2 circuit disabled).

#### LVD1E Bit (Voltage Detection 1 Enable)

When using voltage detection 1 interrupt/reset or the LVD1SR.LVD1MON flag, set the LVD1E bit to 1. The voltage detection 1 circuit starts once td(E-A) passes after the LVD1E bit value is changed from 0 to 1.

### LVD2E Bit (Voltage Detection 2 Enable)

When using voltage detection 2 interrupt/reset or the LVD2SR.LVD2MON flag, set the LVD2E bit to 1. The voltage detection 2 circuit starts once td(E-A) passes after the LVD2E bit value is changed from 0 to 1.

## 8.2.6 Voltage Detection Level Select Register (LVDLVLR)

Address(es): 0008 C298h



Note 1. The value after a reset is the same as the value of the OFS1.STUPLVD1LVL[3:0] bits when the OSF1.STUPLVD1REN bit is 0.

| Bit      | Symbol       | Bit Name                                                                      | Description                                                                                                                                                                                                                                        | R/W |
|----------|--------------|-------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0 | LVD1LVL[3:0] | Voltage Detection 1 Level Select<br>(Standard voltage during drop in voltage) | b3 b0   0 1 0 0: 3.10 V   0 1 0 1: 3.00 V   0 1 1 0: 2.90 V   0 1 1 1: 2.79 V   1 0 0 0: 2.68 V   1 0 1 0: 2.58 V   1 0 1 0: 2.48 V   1 0 1 1: 2.06 V   1 1 0 0: 1.96 V   1 1 0 1: 1.86 V   Settings other than those listed above are prohibited. | R/W |
| b5, b4   | LVD2LVL[1:0] | Voltage Detection 2 Level Select<br>(Standard voltage during drop in voltage) | b5 b4<br>0 0: 2.90 V<br>0 1: 2.60 V<br>1 0: 2.00 V<br>1 1: 1.80 V *1                                                                                                                                                                               | R/W |
| b7, b6   | _            | Reserved                                                                      | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                | R/W |

Note: Set the PRCR.PRC3 bit to 1 (write enabled) before rewriting this register.

Note 1. Do not set these bits to 11b when the LVCMPCR.EXVCCINP2 bit is 0 (power supply voltage (VCC)).

When changing the LVDLVLR register, first set the LVCMPCR.LVD1E and LVCMPCR.LVD2E bits to 0 (voltage detection n circuit disabled) (n = 1, 2).

When a setting is made so that the voltage detection level range set by the LVD1LVL register overlaps with the range set by the LVD2LVL register, it cannot be specified which of LVD1 and LVD2 is used for voltage detection. For details on the voltage detection level range, refer to section 32, Electrical Characteristics.

## 8.2.7 Voltage Monitoring 1 Circuit Control Register 0 (LVD1CR0)

Address(es): 0008 C29Ah



#### x: Undefined

Note 1. The value after a reset is 0 when the OSF1.STUPLVD1REN bit is 0.

Note 2. The value after a reset is 1 when the OSF1.STUPLVD1REN bit is 0.

| Bit    | Symbol   | Bit Name                                                        | Description                                                                                                                                                                          | R/W |
|--------|----------|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0     | LVD1RIE  | Voltage Monitoring 1 Interrupt/Reset<br>Enable                  | 0: Disabled<br>1: Enabled                                                                                                                                                            | R/W |
| b1     | _        | Reserved                                                        | This bit is read as 0. The write value should be 0.                                                                                                                                  | R/W |
| b2     | LVD1CMPE | Voltage Monitoring 1 Circuit Comparison<br>Result Output Enable | on 0: Voltage monitoring 1 circuit comparison results output disabled 1: Voltage monitoring 1 circuit comparison results output enabled                                              |     |
| b3     | _        | Reserved                                                        | The read value is undefined. The write value should be 0.                                                                                                                            | R/W |
| b5, b4 | _        | Reserved                                                        | These bits are read as 0. The write value should be 0.                                                                                                                               | R/W |
| b6     | LVD1RI   | Voltage Monitoring 1 Circuit Mode Select                        | O: Voltage monitoring 1 interrupt occurs when the voltage passes Vdet1     : Voltage monitoring 1 reset occurs when the voltage falls below Vdet1                                    | R/W |
| b7     | LVD1RN   | Voltage Monitoring 1 Circuit Reset<br>Negation Select           | O: Negation follows a stabilization time (tLVD1) after VCC > Vdet1 is detected.  1: Negation follows a stabilization time (tLVD1) after assertion of the voltage monitoring 1 reset. | R/W |

Note: Set the PRCR.PRC3 bit to 1 (write enabled) before rewriting this register.

### LVD1RIE Bit (Voltage Monitoring 1 Interrupt/Reset Enable)

The LVD1RIE bit is enabled when the LVCMPCR.LVD1E bit is set to 1 (voltage detection 1 circuit enabled) and the LVD1CMPE bit is set to 1 (voltage monitoring 1 circuit comparison results output enabled).

Ensure that neither a voltage monitoring 1 reset nor a voltage monitoring 1 non-maskable interrupt is generated during programming or erasure of the flash memory.

#### LVD1RN Bit (Voltage Monitoring 1 Reset Negate Select)

If the LVD1RN bit is to be set to 1 (negation follows a stabilization time after assertion of the voltage monitoring 1 reset), set the LOCOCR.LCSTP bit to 0 (LOCO is operating). Furthermore, if a transition to software standby mode, the only possible value for the LVD1RN bit is 0 (negation follows a stabilization time after VCC > Vdet1 is detected). Do not set the LVD1RN bit to 1 (negation follows a stabilization time after assertion of the voltage monitoring 1 reset).

## 8.2.8 Voltage Monitoring 2 Circuit Control Register 0 (LVD2CR0)

Address(es): 0008 C29Bh



x: Undefined

| Bit    | Symbol                                          | Bit Name                                                        | Description                                                                                                                                                                                           | R/W |
|--------|-------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0     | LVD2RIE                                         | Voltage Monitoring 2 Interrupt/Reset<br>Enable                  | 0: Disabled<br>1: Enabled                                                                                                                                                                             | R/W |
| b1     | _                                               | Reserved                                                        | This bit is read as 0. The write value should be 0.                                                                                                                                                   | R/W |
| b2     | LVD2CMPE                                        | Voltage Monitoring 2 Circuit Comparison<br>Result Output Enable | Voltage monitoring 2 circuit comparison results output disabled     Voltage monitoring 2 circuit comparison results output enabled                                                                    | R/W |
| b3     | _                                               | Reserved                                                        | The read value is undefined. The write value should be 0.                                                                                                                                             | R/W |
| b5, b4 | _                                               | Reserved                                                        | These bits are read as 0. The write value should be 0.                                                                                                                                                | R/W |
| b6     | LVD2RI Voltage Monitoring 2 Circuit Mode Select |                                                                 | <ul><li>0: Voltage monitoring 2 interrupt during Vdet2 passage</li><li>1: Voltage monitoring 2 reset enabled when the voltage falls to and below Vdet2</li></ul>                                      |     |
| b7     | LVD2RN                                          | Voltage Monitoring 2 Circuit Reset<br>Negation Select           | O: Negation follows a stabilization time (tLVD2) after VCC or the CMPA2 pin > Vdet2 is detected.  1: Negation follows a stabilization time (tLVD2) after assertion of the voltage monitoring 2 reset. | R/W |

Note: Set the PRCR.PRC3 bit to 1 (write enabled) before rewriting this register.

### LVD2RIE Bit (Voltage Monitoring 2 Interrupt/Reset Enable)

The LVD2RIE bit is enabled when the LVCMPCR.LVD2E bit is set to 1 (voltage detection 2 circuit enabled) and the LVD2CMPE bit is set to 1 (voltage monitoring 2 circuit comparison results output enabled).

Ensure that neither a voltage monitoring 2 reset nor a voltage monitoring 2 non-maskable interrupt is generated during programming or erasure of the flash memory.

#### LVD2RN Bit (Voltage Monitoring 2 Reset Negate Select)

If the LVD2RN bit is to be set to 1 (negation follows a stabilization time after assertion of the voltage monitoring 2 reset), set the LOCOCR.LCSTP bit to 0 (LOCO is operating). Furthermore, if a transition to software standby mode, the only possible value for the LVD2RN bit is 0 (negation follows a stabilization time after VCC or the CMPA2 pin > Vdet2 is detected). Do not set the LVD2RN bit to 1 (negation follows a stabilization time after assertion of the voltage monitoring 2 reset).

## 8.3 VCC Input Voltage Monitor

## 8.3.1 Monitoring Vdet1

After making the following settings, the LVD1SR.LVD1MON flag can be used to monitor the results of comparison by voltage monitor 1.

- (1) Specify the detection voltage by setting the LVDLVLR.LVD1LVL[3:0] bits (voltage detection 1 level select).
- (2) Set the LVCMPCR.LVD1E bit to 1 (voltage detection 1 circuit enabled).
- (3) After waiting for td(E-A), set the LVD1CR0.LVD1CMPE bit to 1 (voltage monitoring 1 circuit comparison results output enabled).

### 8.3.2 Monitoring Vdet2

After making the following settings, the LVD2SR.LVD2MON flag can be used to monitor the results of comparison by voltage monitor 2.

- (1) Specify the detection voltage by setting the LVDLVLR.LVD2LVL[1:0] bits (voltage detection 2 level).
- (2) Set the LVCMPCR.EXVCCINP2 bit to 0 (VCC voltage) or 1 (CMPA2 pin input voltage).
- (3) Set the LVCMPCR.LVD2E bit to 1 (voltage detection 2 circuit enabled).
- (4) After waiting for td(E-A), set the LVD2CR0.LVD2CMPE bit to 1 (voltage monitoring 2 circuit comparison results output enabled).

## 8.4 Interrupt and Reset from Voltage Monitoring 1

Table 8.3 shows the procedures for setting bits related to the voltage monitoring 1 interrupt and voltage monitoring 1 reset. Table 8.4 shows the procedures for stopping bits related to the voltage monitoring 1 interrupt and voltage monitoring 1 reset. Figure 8.4 shows an example of operations for a voltage monitoring 1 interrupt. For the operation of the voltage monitoring 1 reset, see Figure 6.2 in section 6, Resets.

Table 8.3 Procedures for Setting Bits Related to the Voltage Monitoring 1 Interrupt and Voltage Monitoring 1
Reset

| Step | Voltage Monitoring 1 Interrupt                                                                                                                           | Voltage Monitoring 1 Reset                                                                                                          |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1*1  | Select the detection voltage by setting the LVDLVLR.LVD1LVL[3:0] bits.                                                                                   |                                                                                                                                     |  |  |
| 2*1  | Set the LVD1CR0.LVD1RI bit to 0 (voltage monitoring 1 interrupt).                                                                                        | Set the LVD1CR0.LVD1RI bit to 1 (voltage monitoring 1 reset).  Select the type of reset negation by setting the LVD1CR0.LVD1RN bit. |  |  |
| 3    | Select the timing of interrupt requests by setting the LVD1CR1.LVD1IDTSEL[1:0] bits. Select the type of interrupt by setting the LVD1CR1.LVD1IRQSEL bit. | _                                                                                                                                   |  |  |
| 4    | _                                                                                                                                                        | Set the LVD1CR0.LVD1RIE bit to 1 (voltage monitoring 1 interrupt/reset enabled).                                                    |  |  |
| 5*1  | Set the LVCMPCR.LVD1E bit to 1 (voltage detection 1 circuit enabled).                                                                                    |                                                                                                                                     |  |  |
| 6*1  | Wait for at least td(E-A).                                                                                                                               |                                                                                                                                     |  |  |
| 7    | Set the LVD1CR0.LVD1CMPE bit to 1 (voltage monitoring 1 circuit comparison results output enabled).                                                      |                                                                                                                                     |  |  |
| 8    | Set the LVD1SR.LVD1DET bit to 0.                                                                                                                         | _                                                                                                                                   |  |  |
| 9    | Set the LVD1CR0.LVD1RIE bit to 1 (voltage monitoring 1 interrupt/reset enabled).                                                                         | _                                                                                                                                   |  |  |

Note 1. Steps 1, 2, 5, and 6 are not required if operation is with the setting to select the voltage monitoring 1 interrupt (LVD1CR0.LVD1RI = 0) and operation can be restarted by simply changing the settings of the LVD1CR1.LVD1IRQSEL and LVD1IDTSEL[1:0] bits after monitoring is stopped or if restarting is in a case where the settings related to the voltage-detection circuit were not changed after monitoring was stopped. When changes are to be made and operation is with the setting to select the voltage monitoring 1 reset (LVD1CR0.LVD1RI = 1), proceed through all steps from 1 to 9.

Table 8.4 Procedures for Stopping Bits Related to the Voltage Monitoring 1 Interrupt and Voltage Monitoring 1 Reset

| Step | Voltage Monitoring 1 Interrupt                                                                                                              | Voltage Monitoring 1 Reset |  |  |
|------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|--|--|
| 1    | Set the LVD1CR0.LVD1RIE bit to 0 (voltage monitoring 1 interrupt/reset disabled).                                                           | _                          |  |  |
| 2    | Set the LVD1CR0.LVD1CMPE bit to 0 (voltage monitoring 1 circuit comparison results output disabled).                                        |                            |  |  |
| 3*1  | Set the LVCMPCR.LVD1E bit to 0 (voltage detection 1 circuit disabled).                                                                      |                            |  |  |
| 4    | — Set the LVD1CR0.LVD1RIE bit to 0 (voltage monitoring 1 interrupt/reset disabled).                                                         |                            |  |  |
| 5    | Modify settings of bits related to the voltage detection circuit registers other than LVCMPCR.LVD1E, LVD1CR0.LVD1RIE, and LVD1CR0.LVD1CMPE. |                            |  |  |

Note 1. Step 3 is not required if operation is with the setting to select the voltage monitoring 1 interrupt (LVD1CR0.LVD1RI = 0) and operation can be restarted by simply changing the settings of the LVD1CR1.LVD1IRQSEL and LVD1IDTSEL[1:0] bits after monitoring is stopped or if restarting is in a case where the settings related to the voltage-detection circuit were not changed after monitoring was stopped. When changes are to be made and operation is with the setting to select the voltage monitoring 1 reset (LVD1CR0.LVD1RI = 1), proceed through all steps from 1 to 5.



Figure 8.4 Example of Voltage Monitoring 1 Interrupt Operation

## 8.5 Interrupt and Reset from Voltage Monitoring 2

Table 8.5 shows the procedures for setting bits related to the voltage monitoring 2 interrupt and voltage monitoring 2 reset. Table 8.6 shows the procedure for stopping bits related to the voltage monitoring 2 interrupt and voltage monitoring 2 reset. Figure 8.5 shows an example of operations for a voltage monitoring 2 interrupt. For the operation of the voltage monitoring 2 reset, see Figure 6.2 in section 6, Resets.

Table 8.5 Procedures for Setting Bits Related to the Voltage Monitoring 2 Interrupt and Voltage Monitoring 2
Reset

| Step | Voltage Monitoring 2 Interrupt                                                                                                                           | Voltage Monitoring 2 Reset                                                                                                          |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1*1  | Select the detection voltage by setting the LVDLVLR.LVD2LVL[1:0] bits.                                                                                   |                                                                                                                                     |  |  |
| 2*1  | Set the LVCMPCR.EXVCCINP2 bit to 0 (VCC voltage) or set                                                                                                  | it to 1 (CMPA2 pin input voltage).                                                                                                  |  |  |
| 3*1  | Set the LVD2CR0.LVD2RI bit to 0 (voltage monitoring 2 interrupt).                                                                                        | Set the LVD2CR0.LVD2RI bit to 1 (voltage monitoring 2 reset).  Select the type of reset negation by setting the LVD2CR0.LVD2RN bit. |  |  |
| 4    | Select the timing of interrupt requests by setting the LVD2CR1.LVD2IDTSEL[1:0] bits. Select the type of interrupt by setting the LVD2CR1.LVD2IRQSEL bit. | _                                                                                                                                   |  |  |
| 5    | _                                                                                                                                                        | Set the LVD2CR0.LVD2RIE bit to 1 (voltage monitoring 2 interrupt/reset enabled).                                                    |  |  |
| 6*1  | Set the LVCMPCR.LVD2E bit to 1 (voltage detection 2 circuit                                                                                              | enabled).                                                                                                                           |  |  |
| 7*1  | Wait for at least td(E-A).                                                                                                                               |                                                                                                                                     |  |  |
| 8    | Set the LVD2CR0.LVD2CMPE bit to 1 (voltage monitoring 2 circuit comparison results output enabled).                                                      |                                                                                                                                     |  |  |
| 9    | Set the LVD2SR.LVD2DET bit to 0.                                                                                                                         |                                                                                                                                     |  |  |
| 10   | Set the LVD2CR0.LVD2RIE bit to 1 (voltage monitoring 2 interrupt/reset enabled)                                                                          | _                                                                                                                                   |  |  |

Note 1. Steps 1, 2, 3, 6, and 7 are not required if operation is with the setting to select the voltage monitoring 2 interrupt (LVD2CR0.LVD2RI = 0) and operation can be restarted by simply changing the settings of the LVD2CR1.LVD2IRQSEL and LVD2IDTSEL[1:0] bits after monitoring is stopped or if restarting is in a case where the settings related to the voltage-detection circuit were not changed after monitoring was stopped. When changes are to be made and operation is with the setting to select the voltage monitoring 2 reset (LVD2CR0.LVD2RI = 1), proceed through all steps from 1 to 10.

Table 8.6 Procedures for Stopping Bits Related to the Voltage Monitoring 2 Interrupt and Voltage Monitoring 2 Reset

| Step | Voltage Monitoring 2 Interrupt                                                                                                             | Voltage Monitoring 2 Reset                                                        |  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|
| 1    | Set the LVD2CR0.LVD2RIE bit to 0 (voltage monitoring 2 interrupt/reset disabled).                                                          | _                                                                                 |  |
| 2    | Set the LVD2CR0.LVD2CMPE bit to 0 (voltage monitoring 2 circuit comparison results output disabled).                                       |                                                                                   |  |
| 3*1  | Set the LVCMPCR.LVD2E bit to 0 (voltage monitoring 2 circuit disabled).                                                                    |                                                                                   |  |
| 4    | _                                                                                                                                          | Set the LVD2CR0.LVD2RIE bit to 0 (voltage monitoring 2 interrupt/reset disabled). |  |
| 5    | Modify settings of bits related to the voltage detection circuit registers other than LVCMPCR.LVD2E, LVD2CR0.LVD2RIE, an LVD2CR0.LVD2CMPE. |                                                                                   |  |

Note 1. Step 3 is not required if operation is with the setting to select the voltage monitoring 2 interrupt (LVD2CR0.LVD2RI = 0) and operation can be restarted by simply changing the settings of the LVD2CR1.LVD2IRQSEL and LVD2IDTSEL[1:0] bits after monitoring is stopped or if restarting is in a case where the settings related to the voltage-detection circuit were not changed after monitoring was stopped. When changes are to be made and operation is with the setting to select the voltage monitoring 2 reset (LVD2CR0.LVD2RI = 1), proceed through all steps from 1 to 5.



Figure 8.5 Example of Voltage Monitoring 2 Interrupt Operation

## 9. Clock Generation Circuit

### 9.1 Overview

This MCU incorporates a clock generation circuit.

Table 9.1 lists the specifications of the clock generation circuit. Figure 9.1 shows a block diagram of the clock generation circuit.

Table 9.1 Specifications of Clock Generation Circuit

| Item                                 | Specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Uses                                 | <ul> <li>Generates the system clock (ICLK) to be supplied to the CPU, DTC, ROM, and RAM.</li> <li>Generates the peripheral module clocks (PCLKB and PCLKD) to be supplied to peripheral modules.</li> <li>The peripheral module clock used as the operating clock is PCLKD for S12AD and PCLKB for other modules.</li> <li>Generates the FlashIF clock (FCLK) to be supplied to the FlashIF.</li> <li>Generates the CAC clock (CACCLK) to be supplied to the CAC.</li> <li>Generates the RTC-dedicated sub-clock (RTCSCLK) to be supplied to the RTC.</li> <li>Generates the IWDT-dedicated low-speed clock (IWDTCLK) to be supplied to the IWDT.</li> </ul> |
| Operating frequencies*1              | <ul> <li>ICLK: 32 MHz (max)*2</li> <li>PCLKB: 32 MHz (max)*2</li> <li>PCLKD: 32 MHz (max)*2</li> <li>FCLK: 1 to 32 MHz (for programming and erasing the ROM)</li> <li>CACCLK: Same frequency as each oscillator</li> <li>RTCSCLK: 32.768 kHz</li> <li>IWDTCLK: 15 kHz</li> </ul>                                                                                                                                                                                                                                                                                                                                                                             |
| Main clock oscillator                | <ul> <li>Resonator frequency: 1 to 20 MHz (VCC ≥ 2.4 V), 1 to 8 MHz (VCC &lt; 2.4 V)</li> <li>External clock input frequency: 20 MHz (max)</li> <li>Connectable resonator or additional circuit: ceramic resonator, crystal</li> <li>Connection pins: EXTAL, XTAL</li> <li>Oscillation stop detection function: When a main clock oscillation stop is detected, the system clock source is switched to LOCO and MTU output can be forcedly driven to high-impedance.</li> </ul>                                                                                                                                                                              |
| Sub-clock oscillator                 | <ul> <li>Resonator frequency: 32.768 kHz</li> <li>Connectable resonator or additional circuit: crystal</li> <li>Connection pin: XCIN, XCOUT</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| High-speed on-chip oscillator (HOCO) | Oscillation frequency: 32 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Low-speed on-chip oscillator (LOCO)  | Oscillation frequency: 4 MHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| IWDT-dedicated on-chip oscillator    | Oscillation frequency: 15 kHz                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

Note 1. The maximum operating frequency in high-speed operating mode. For the maximum operating frequency in the other operating modes, refer to section 11.2.5, Operating Power Control Register (OPCCR).

Note 2. The relationship of frequencies must be set as follows. ICLK: FCLK, PCLKB, and PCLKD = N: 1 (N is an integer)



Figure 9.1 Block Diagram of Clock Generation Circuit

Table 9.2 lists the I/O pins of the clock generation circuit.

Table 9.2 I/O Pins of Clock Generation Circuit

| Pin Name | I/O            | Description                                                                         |
|----------|----------------|-------------------------------------------------------------------------------------|
| XTAL     | Output/Input*1 | These pins are used to connect a crystal. The XTAL pin can also be used to input an |
| EXTAL    | Input          | external clock. For details, refer to section 9.3.2, External Clock Input.          |
| XCIN     | Input          | These pins are used to connect a 32.768-kHz crystal.                                |
| XCOUT    | Output         |                                                                                     |
| CLKOUT   | Output         | Clock output pin                                                                    |

Note 1. For external clock input.

## 9.2 Register Descriptions

# 9.2.1 System Clock Control Register (SCKCR)

Address(es): 0008 0020h



| Bit        | Symbol    | Bit Name                                       | Description                                                                                                                                                                             | R/W |
|------------|-----------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0   | PCKD[3:0] | Peripheral Module Clock D<br>(PCLKD) Select *1 | b3 b0<br>0 0 0 0: x1<br>0 0 0 1: x1/2<br>0 0 1 0: x1/4<br>0 0 1 1: x1/8<br>0 1 0 0: x1/16<br>0 1 0 1: x1/32<br>0 1 1 0: x1/64<br>Settings other than those listed above are prohibited. | R/W |
| b7 to b4   | _         | Reserved                                       | These bits are read as 0. The write value should be 0.                                                                                                                                  | R/W |
| b11 to b8  | PCKB[3:0] | Peripheral Module Clock B (PCLKB) Select *1    | b11 b8<br>0 0 0 0: x1<br>0 0 0 1: x1/2<br>0 0 1 0: x1/4<br>0 0 1 1: x1/8<br>0 1 0 0: x1/16<br>0 1 0 1: x1/32<br>0 1 1 0: x1/64<br>Settings other than above are prohibited.             | R/W |
| b23 to b12 | _         | Reserved                                       | These bits are read as 0. The write value should be 0.                                                                                                                                  | R/W |
| b27 to b24 | ICK[3:0]  | System Clock (ICLK)<br>Select *1               | b27 b24<br>0 0 0 0: x1<br>0 0 0 1: x1/2<br>0 0 1 0: x1/4<br>0 0 1 1: x1/8<br>0 1 0 0: x1/16<br>0 1 0 1: x1/32<br>0 1 1 0: x1/64<br>Settings other than above are prohibited.            | R/W |
| b31 to b28 | FCK[3:0]  | FlashIF Clock (FCLK)<br>Select *1              | b31 b28<br>0 0 0 0: x1<br>0 0 0 1: x1/2<br>0 0 1 0: x1/4<br>0 0 1 1: x1/8<br>0 1 0 0: x1/16<br>0 1 0 1: x1/32<br>0 1 1 0: x1/64<br>Settings other than above are prohibited.            | R/W |

Note: Set the PRCR.PRC0 bit to 1 (write enabled) before rewriting this register.

Note 1. The relationship of frequencies must be set as follows. ICLK: FCLK, PCLKB, and PCLKD = 1: N (N is an integer).

This register cannot be rewritten while the flash memory is being programmed or erased.

When an instruction for writing to SCKCR or SCKCR3 is to follow writing to the SCKCR register, do so in accord with the procedure below.



- 1. Write to the SCKCR register.
- 2. Confirm that the value has actually been written to the SCKCR register.
- 3. Proceed to the next step.

## PCKD[3:0] Bits (Peripheral Module Clock (PCLKD) Select)

These bits select the frequency of peripheral module clock D (PCLKD).

## PCKB[3:0] Bits (Peripheral Module Clock (PCLKB) Select)

These bits select the frequency of peripheral module clock B (PCLKB).

## ICK[3:0] Bits (System Clock (ICLK) Select)

These bits select the frequency of the system clock (ICLK).

### FCK[3:0] Bits (FlashIF Clock (FCLK) Select)

These bits select the frequency of the FlashIF clock (FCLK).

## 9.2.2 System Clock Control Register 3 (SCKCR3)

Address(es): 0008 0026h



| Bit        | Symbol     | Bit Name            | Description                                                                                                                       | R/W |
|------------|------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----|
| b7 to b0   | _          | Reserved            | These bits are read as 0. The write value should be 0.                                                                            | R/W |
| b10 to b8  | CKSEL[2:0] | Clock Source Select | b10 b8 0 0 0: LOCO 0 0 1: HOCO 0 1 0: Main clock oscillator 0 1 1: Sub-clock oscillator Settings other than above are prohibited. | R/W |
| b15 to b11 | _          | Reserved            | These bits are read as 0. The write value should be 0.                                                                            | R/W |

Note: Set the PRCR.PRC0 bit to 1 (write enabled) before rewriting this register.

This register cannot be rewritten while the flash memory is being programmed or erased.

### CKSEL[2:0] Bits (Clock Source Select)

These bits select the source of the system clock (ICLK), peripheral module clock (PCLKB and PCLKD), and FlashIF clock (FCLK) from low-speed on-chip oscillator (LOCO), high-speed on-chip oscillator (HOCO), the main clock oscillator, and the sub-clock oscillator.

Transitions to clock sources which are not in operation are prohibited.

# 9.2.3 Main Clock Oscillator Control Register (MOSCCR)

Address(es): 0008 0032h



| Bit      | Symbol | Bit Name                   | Description                                                               | R/W |
|----------|--------|----------------------------|---------------------------------------------------------------------------|-----|
| b0       | MOSTP  | Main Clock Oscillator Stop | Main clock oscillator is operating.     Main clock oscillator is stopped. | R/W |
| b7 to b1 | _      | Reserved                   | These bits are read as 0. The write value should be 0.                    | R/W |

Note: Set the PRCR.PRC0 bit to 1 (write enabled) before rewriting this register.

Set this register after setting up the main clock oscillator wait control register.

### **MOSTP Bit (Main Clock Oscillator Stop)**

This bit runs or stops the main clock oscillator.

After setting the MOSTP bit to 0 (main clock oscillator is operating), read the OSCOVFSR.MOOVF bit to confirm that is has become 1, and then use the main clock.

For the main clock oscillator, a fixed time is required for oscillation to become stable after the settings for operation have been made. Furthermore, a fixed time is required for oscillation to actually stop after the settings to stop oscillation have been made. Accordingly, take note of the following limitations when starting and stopping operation.

- After stopping the main clock oscillator, confirm that the OSCOVFSR.MOOVF bit is 0 before restarting the main clock oscillator.
- Confirm that the main clock oscillator is operating and that the OSCOVFSR.MOOVF bit is 1 before stopping the main clock oscillator.
- Regardless of whether or not it is selected as the system clock, confirm that the OSCOVFSR.MOOVF bit is 1 and
  execute a WAIT instruction in order to operate the main clock oscillator and place the MCU in software standby
  mode.
- After stopping the main clock oscillator, confirm that the OSCOVFSR.MOOVF bit is 0 and execute a WAIT
  instruction before entering software standby mode.

Do not set the MOSTP bit to 1 when the following condition is met.

• When the main clock is selected as the clock source for the system clock (SCKCR3.CKSEL[2:0] = 010b)

Do not set the MOSTP bit to 0 when the following condition is met.

• When low-speed operating mode is selected by the SOPCCR.SOPCM bit

# 9.2.4 Sub-Clock Oscillator Control Register (SOSCCR)

Address(es): 0008 0033h



| Bit      | Symbol | Bit Name                  | Description                                                             | R/W |
|----------|--------|---------------------------|-------------------------------------------------------------------------|-----|
| b0       | SOSTP  | Sub-Clock Oscillator Stop | Sub-clock oscillator is operating.     Sub-clock oscillator is stopped. | R/W |
| b7 to b1 | _      | Reserved                  | These bits are read as 0. The write value should be 0.                  | R/W |

Note: Set the PRCR.PRC0 bit to 1 (write enabled) before rewriting this register.

The XCIN pin is also used as ports. In their initialized state, they function as pins for the sub-clock oscillator.

### **SOSTP Bit (Sub-Clock Oscillator Stop)**

This bit runs or stops the sub-clock oscillator.

The SOSTP bit and the sub-clock oscillator control bit in RTC control register 3 (RCR3.RTCEN) controls whether to operate or stop the sub-clock oscillator. If one of these bits is set so as to enable the operation, the sub-clock oscillator runs.

When changing the value of the SOSTP bit or RCR3.RTCEN bit, execute subsequent instructions after reading the bit and checking that its value has actually been updated (refer to (2), Notes on writing to I/O registers, in section 5, I/O Registers).

After the setting of the SOSTP bit or the RCR3.RTCEN bit has been changed so that the sub-clock oscillator operates, only start using the sub-clock after the sub-clock oscillation stabilization time ( $t_{SUBOSC}$ ) has elapsed.

That is, a fixed time for stabilization is required after the setting for sub-clock oscillator operation. A fixed time is also required for oscillation to stop after the setting to stop the oscillator. Accordingly, take note of the following limitations when starting and stopping the oscillator.

- When restarting the sub-clock oscillator after it has been stopped, allow at least five cycles of the sub-clock as an interval over which it is still stopped.
- Ensure that oscillation by the sub-clock oscillator is stable when making the setting to stop the sub-clock oscillator.
- Regardless of whether or not it is selected as the system clock, ensure that oscillation by the sub-clock oscillator is stable before executing a WAIT instruction to place the chip on software standby.
- When a transition to software standby mode is to follow the setting to stop the sub-clock oscillator, wait for at least
  two cycles of the sub-clock oscillator after the setting to stop the sub-clock oscillator and before executing the
  WAIT instruction.

While the sub-clock oscillator is selected by the SCKCR3.CKSEL[2:0] bits, do not set the SOSTP bit to 1 (sub-clock oscillator is stopped).

# 9.2.5 Low-Speed On-Chip Oscillator Control Register (LOCOCR)

Address(es): 0008 0034h



| Bit      | Symbol | Bit Name  | Description                                            | R/W |
|----------|--------|-----------|--------------------------------------------------------|-----|
| b0       | LCSTP  | LOCO Stop | 0: LOCO is operating. 1: LOCO is stopped.              | R/W |
| b7 to b1 | _      | Reserved  | These bits are read as 0. The write value should be 0. | R/W |

Note: Set the PRCR.PRC0 bit to 1 (write enabled) before rewriting this register.

### LCSTP Bit (LOCO Stop)

This bit runs or stops the LOCO.

After the setting of the LCSTP bit has been changed so that the LOCO operates, only start using the LOCO clock after the LOCO clock oscillation stabilization time ( $t_{LOCO}$ ) has elapsed.

That is, a fixed time for stabilization of oscillation is required after the setting for LOCO operation. A fixed time is also required for oscillation to stop after the setting to stop the oscillator. Accordingly, take note of the following limitations when starting and stopping the oscillator.

- When restarting the LOCO after it has been stopped, allow at least five cycles of the LOCO as an interval over which it is still stopped.
- Ensure that oscillation by the LOCO is stable when making the setting to stop the LOCO.
- Regardless of whether or not it is selected as the system clock, ensure that oscillation by the LOCO is stable before executing a WAIT instruction to place the chip on software standby.
- When a transition to software standby mode is to follow the setting to stop the LOCO, wait for at least three cycles of the LOCO after the setting to stop the LOCO and before executing the WAIT instruction.

While the LOCO is selected by the SCKCR3.CKSEL[2:0] bits, do not set the LCSTP bit to 1 (LOCO is stopped). While low-speed operating mode is selected by the SOPCCR.SOPCM bit, do not set the LCSTP bit to 0 (LOCO is operating).

# 9.2.6 IWDT-Dedicated On-Chip Oscillator Control Register (ILOCOCR)

Address(es): 0008 0035h



| Bit      | Symbol | Bit Name                                  | Description                                                                                                                   | R/W |
|----------|--------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | ILCSTP | IWDT-Dedicated On-Chip<br>Oscillator Stop | <ul><li>0: IWDT-dedicated on-chip oscillator is operating.</li><li>1: IWDT-dedicated on-chip oscillator is stopped.</li></ul> | R/W |
| b7 to b1 | _      | Reserved                                  | These bits are read as 0. The write value should be 0.                                                                        | R/W |

Note: Set the PRCR.PRC0 bit to 1 (write enabled) before rewriting this register.

When the IWDT start mode select bit in option function select register 0 (OFS0.IWDTSTRT) is 0 (IWDT is operating), the setting of this register is invalid; it is valid only when the OFS0.IWDTSTRT bit is set to 1 (IWDT is stopped). The ILCSTP bit cannot be changed from 0 (IWDT-dedicated on-chip oscillator is operating) to 1 (IWDT-dedicated on-chip oscillator is stopped) while ILOCOCR is valid.

### **ILCSTP Bit (IWDT-Dedicated On-Chip Oscillator Stop)**

This bit runs or stops the IWDT-dedicated on-chip oscillator.

After the setting of the ILCSTP bit has been changed so that the IWDT-dedicated on-chip oscillator operates, supply of the clock is started the MCU internally after a fixed time corresponding to the IWDT-dedicated clock oscillation stabilization time (t<sub>ILOCO</sub>) has elapsed.

If the IWDT-dedicated clock is to be used, only start using the oscillator after this wait time has elapsed.

Ensure that oscillation by the IWDT-dedicated on-chip oscillator is stable before executing a WAIT instruction to place the chip on software standby mode.

# 9.2.7 High-Speed On-Chip Oscillator Control Register (HOCOCR)

Address(es): 0008 0036h



Note 1. The HCSTP bit value after a reset is 0 when the HOCO oscillation enable bit in option function select register 1 (OFS1.HOCOEN) is 0. The HCSTP bit value after a reset is 1 when the OFS1.HOCOEN bit is 1.

| Bit      | Symbol | Bit Name  | Description                                            | R/W |
|----------|--------|-----------|--------------------------------------------------------|-----|
| b0       | HCSTP  | HOCO Stop | 0: HOCO is operating. 1: HOCO is stopped.              | R/W |
| b7 to b1 | _      | Reserved  | These bits are read as 0. The write value should be 0. | R/W |

Note: Set the PRCR.PRC0 bit to 1 (write enabled) before rewriting this register.

Set the high-speed on-chip wait control register before setting this register.

### **HCSTP Bit (HOCO Stop)**

This bit runs or stops the HOCO.

When changing the HCSTP bit from 1 to 0 (i.e. changing the HOCO clock from stopped to operating), confirm that the OSCOVFSR.HCOVF bit is 1 before switching the system clock to the HOCO clock.

That is, a fixed time for stabilization of oscillation is required after the setting for HOCO operation. A fixed time is also required for oscillation to stop after the setting to stop the oscillator. Accordingly, take note of the following limitations when starting and stopping the oscillator.

- After stopping the HOCO, confirm that the OSCOVFSR.HCOVF bit is 0 before restarting the HOCO.
- Confirm that the HOCO is operating and that the OSCOVFSR.HCOVF bit is 1 before stopping the HOCO.
- Regardless of whether or not it is selected as the system clock, confirm that the OSCOVFSR.HCOVF bit is 1 before executing a WAIT instruction to place the MCU in software standby mode.
- After stopping the HOCO, confirm that the OSCOVFSR.HCOVF bit is 0 and execute a WAIT instruction before entering software standby mode.

While the HOCO is selected by the SCKCR3.CKSEL[2:0] bits, do not set the HCSTP bit to 1 (HOCO is stopped). While low-speed operating mode is selected by the SOPCCR.SOPCM bit, do not set the HCSTP bit to 0 (HOCO is operating).

# 9.2.8 Oscillation Stabilization Flag Register (OSCOVFSR)

Address(es): 0008 003Ch



Note 1. The HCOVF value after a reset is 1 when the HOCO oscillation enable bit in option function selection register 1 (OFS1.HOCOEN) is 0. The HCSTP value after a reset is 1 when the OFS1.HOCOEN bit is 0.

| Bit      | Symbol | Bit Name                                     | Description                                                                                                   | R/W |
|----------|--------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------|-----|
| b0       | MOOVF  | Main Clock Oscillation<br>Stabilization Flag | 0: Main clock is stopped 1: Oscillation is stable and the clock can be used as the system clock*1             | R   |
| b2 to b1 | _      | Reserved                                     | These bits are read as 0. The write value should be 0.                                                        | R/W |
| b3       | HCOVF  | HOCO Clock Oscillation<br>Stabilization Flag | 0: HOCO is stopped or not stabilized 1: Oscillation is stable and the clock can be used as the system clock*1 | R   |
| b7 to b4 | _      | Reserved                                     | These bits are read as 0. The write value should be 0.                                                        | R/W |

Note 1. When an appropriate value is set in the wait control register for each oscillator. If a set value (wait time) is not adequate, clock supply starts before oscillation becomes stable.

The OSCOVFSR register monitors whether oscillation of each oscillator has become stable.

If a wait control register is provided for each oscillator, specify a wait time that is longer than or equal to the stabilization time of the corresponding oscillation circuit.

#### **MOOVF Flag (Main Clock Oscillation Stabilization Flag)**

This flag indicates whether oscillation of the main clock is stable. [Setting condition]

 After the MOSCCR.MOSTP bit is set to 0 (main clock oscillator is operating) when the MOSTP bit is 1 (main clock oscillator is stopped), the corresponding time set in the MOSCWTCR register has elapsed and supply of the main clock is started to the MCU internally.

[Clearing condition]

• After the MOSCCR.MOSTP bit is set to 1, the processing to stop the oscillation of the main clock oscillator is completed.

### **HCOVF Flag (HOCO Clock Oscillation Stabilization Flag)**

This flag indicates whether oscillation of the HOCO clock is stable. [Setting condition]

- After the HOCOCR.HCSTP bit is set to 0 (HOCO is operating) when the HCSTP bit is 1 (HOCO is stopped), the corresponding time set in the register has elapsed and supply of the HOCO clock is started to the MCU internally. [Clearing condition]
- After the HOCOCR.HCSTP bit is set to 1, the processing to stop the oscillation of the HOCO is completed.

# 9.2.9 Oscillation Stop Detection Control Register (OSTDCR)

Address(es): 0008 0040h



| Bit      | Symbol | Bit Name                                       | Description                                                                                                                                | R/W |
|----------|--------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | OSTDIE | Oscillation Stop Detection<br>Interrupt Enable | <ul><li>0: The oscillation stop detection interrupt is disabled.</li><li>1: The oscillation stop detection interrupt is enabled.</li></ul> | R/W |
| b6 to b1 | _      | Reserved                                       | These bits are read as 0. The write value should be 0.                                                                                     | R/W |
| b7       | OSTDE  | Oscillation Stop Detection Function Enable     | Oscillation stop detection function is disabled.     Scillation stop detection function is enabled.                                        | R/W |

Note: Set the PRCR.PRC0 bit to 1 (write enabled) before rewriting this register.

### **OSTDIE Bit (Oscillation Stop Detection Interrupt Enable)**

If the oscillation stop detection flag in the oscillation stop detection status register (OSTDSR.OSTDF) requires clearing, do this after setting the OSTDIE bit to 0. Wait for at least two cycles of PCLKB before again setting the OSTDIE bit to 1. According to the number of cycles for access to read a given I/O register, wait time longer than two cycles of PCLKB may have to be secured.

### **OSTDE Bit (Oscillation Stop Detection Function Enable)**

This bit enables or disables the oscillation stop detection function.

When the OSTDE bit is 1 (oscillation stop detection function enabled), the LOCO stop bit (LOCOCR.LCSTP) is set to 0 and the LOCO operation is started. The LOCO cannot be stopped while the oscillation stop detection function is enabled; writing 1 (LOCO is stopped) to the LOCOCR.LCSTP bit is invalid.

When the oscillation stop detection flag in the oscillation stop detection status register (OSTDSR.OSTDF) is 1 (main clock oscillation stop has been detected), writing 0 to the OSTDE bit is invalid.

When the OSTDE bit is 1, a transition cannot be made to software standby mode. To make a transition to software standby mode, execute the WAIT instruction with the OSTDE bit being 0.

# 9.2.10 Oscillation Stop Detection Status Register (OSTDSR)

Address(es): 0008 0041h



| Bit      | Symbol | Bit Name                        | Description                                                                                                  | R/W         |
|----------|--------|---------------------------------|--------------------------------------------------------------------------------------------------------------|-------------|
| b0       | OSTDF  | Oscillation Stop Detection Flag | O: The main clock oscillation stop has not been detected. The main clock oscillation stop has been detected. | R/(W)<br>*1 |
| b7 to b1 | _      | Reserved                        | These bits are read as 0 and cannot be modified.                                                             | R           |

Note: Set the PRCR.PRC0 bit to 1 (write enabled) before rewriting this register.

Note 1. This bit can only be set to 0.

### **OSTDF Flag (Oscillation Stop Detection Flag)**

This bit is a flag to indicate the main clock status. When the OSTDF flag is 1, it indicates that the main clock oscillation stop has been detected.

Once the main clock oscillation stop is detected, the OSTDF flag is not set to 0 even though the main clock oscillation is restarted. The OSTDF flag is set to 0 by reading 1 from the bit and then writing 0. At least three ICLK cycles of wait time is necessary between writing 0 to the OSTDF flag and reading the OSTDF flag as 0. If the OSTDF flag is set to 0 while the main clock oscillation is stopped, the OSTDF flag becomes 0 and then returns to 1.

When the main clock oscillator (010b) is selected by the clock source select bits in system clock control register 3 (SCKCR3.CKSEL[2:0]), the OSTDF flag cannot be modified to 0. The OSTDF flag should be set to 0 after switching the clock source to a source other than the main clock oscillator.

### [Setting condition]

• The main clock oscillation is stopped with the OSTDCR.OSTDE bit being 1 (oscillation stop detection function enabled).

#### [Clearing condition]

• 1 is read and then 0 is written when the SCKCR3.CKSEL[2:0] bits are not 010b.

# 9.2.11 Main Clock Oscillator Wait Control Register (MOSCWTCR)

Address(es): 0008 00A2h



| Bit      | Symbol    | Bit Name                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R/W |
|----------|-----------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | MSTS[4:0] | Main Clock Oscillator Wait Time | b4 0 0 0 0 0: Wait time = 2 cycles (0.5 μs) 0 0 0 0 1: Wait time = 1024 cycles (256 μs) 0 0 0 1 0: Wait time = 2048 cycles (512 μs) 0 0 0 1 1: Wait time = 2048 cycles (512 μs) 0 0 0 1 1: Wait time = 4096 cycles (1.024 ms) 0 0 1 0 0: Wait time = 8192 cycles (2.048 ms) 0 0 1 0 1: Wait time = 16384 cycles (4.096 ms) 0 0 1 1 0: Wait time = 32768 cycles (8.192 ms) 0 0 1 1 1: Wait time = 65536 cycles (16.384 ms) Settings other than above are prohibited. Wait time when LOCO = 4.0 MHz (0.25 μs, TYP.) | R/W |
| b7 to b5 | _         | Reserved                        | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R/W |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

### MSTS[4:0] Bits (Main Clock Oscillator Wait Time)

Set these bits to select the oscillation stabilization wait time of the main clock oscillator.

Set the main clock oscillation stabilization time to longer than or equal to the stabilization time recommended by the oscillator manufacturer. When the main clock is externally input, set these bits to 00000b because the oscillation stabilization time is not required.

The wait time set by the MSTS[4:0] bits is counted using the LOCO clock. The LOCO automatically oscillates when necessary, regardless of the value of the LOCOCR.LOSTP bit.

After the set wait time has elapsed, supply of the main clock is started to the MCU internally and the

OSCOVFSR.MOOVF flag becomes 1. If the set wait time is short, supply of the main clock is started before oscillation of the clock becomes stable.

Only rewrite the MOSCWTCR register when the MOSCCR.MOSTP bit is 1 and the OSCOVFSR.MOOVF flag is 0. Do not rewrite this register under any other conditions.

# 9.2.12 High-Speed On-Chip Oscillator Wait Control Register (HOCOWTCR)

Address(es): 0008 00A5h



| Bit      | Symbol    | Bit Name                                   | Description                                                                                                                                         | R/W |
|----------|-----------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | HSTS[4:0] | High-Speed On-Chip Oscillator<br>Wait Time | b4 b0 0 1 1: Wait time = 138 cycles (34.5 μs)*1, *2, *4 0 0 1 1 0: Wait time = 266 cycles (66.5 μs)*3, *4 Settings other than above are prohibited. | R/W |
| b7 to b5 | _         | Reserved                                   | These bits are read as 0. The write value should be 0.                                                                                              | R/W |

Note: Set the PRCR.PRC2 bit to 1 (write enabled) before rewriting this register.

- Note 1. If this value is set, the HOCO oscillation stabilization time (t<sub>HOCO</sub>) is not secured, so the HOCO frequency accuracy shown in Electrical Characteristics is not guaranteed when supply of the clock starts. When t<sub>HOCO</sub> has elapsed after oscillation starts, the HOCO frequency accuracy is as shown in Electrical Characteristics.
- Note 2. When the OFS1.HOCOEN bit is set to 0, the HOCO oscillation stabilization time (t<sub>HOCO</sub>) is secured by hardware, so the clock with the accuracy of the HOCO frequency (f<sub>HOCO</sub>) shown in Electrical Characteristics is supplied after release from the CPU reset state.
- Note 3. When this value is set, the HOCO oscillation stabilization time (t<sub>HOCO</sub>) is secured and the clock with the accuracy of the HOCO frequency (f<sub>HOCO</sub>) shown in Electrical Characteristics is supplied after release from the CPU reset state.
- Note 4. Wait time when LOCO =  $4.0 \text{ MHz} (0.25 \mu \text{s}, \text{TYP.})$

### HSTS[4:0] Bits (High-Speed On-Chip Oscillator Wait Time)

These bits are used to select the oscillation stabilization wait time of the HOCO when setting HOCO operation (the HOCOCR.HCSTP bit to 0) and when canceling software standby mode.

Supply of the HOCO clock is started to the MCU internally after the number of LOCO cycles set by the HSTS[4:0] bits has been counted. Counting of LOCO cycles proceeds regardless of the setting of the LOCOCR.LOSTP bit and hardware automatically controls running and stopping the LOCO.

The clock is not supplied to the MCU internally until counting is completed.

After counting is completed, supply of the clock is started to the MCU internally and the OSCOVFSR.HCOVF flag is set to 1.

The HOCOWTCR register can be rewritten under the following cases. Otherwise, do not rewrite this register.

- When the HOCOCR.HCSTP bit is set to 0 (operating), and the OSCOVFSR.HCOVF flag is read and confirmed to be 1.
- When the HOCOCR.HCSTP bit is set to 1 (stopped), and the OSCOVFSR.HCOVF flag is read and confirmed to be

# 9.2.13 CLKOUT Output Control Register (CKOCR)

Address(es): 0008 003Eh



| Bit        | Symbol      | Bit Name                               | Description                                                                                                                                   | R/W |
|------------|-------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b7 to b0   | _           | Reserved                               | These bits are read as 0. The write value should be 0.                                                                                        | R/W |
| b10 to b8  | CKOSEL[2:0] | CLKOUT Output Source Select            | b10 b8 0 0 0: LOCO clock 0 0 1: HOCO clock 0 1 0: Main clock oscillator 0 1 1: Sub-clock oscillator Settings other than above are prohibited. | R/W |
| b11        | _           | Reserved                               | This bit is read as 0. The write value should be 0.                                                                                           | R/W |
| b14 to b12 | CKODIV[2:0] | CLKOUT Output Division Ratio<br>Select | b14 b2<br>0 0 0: No division<br>0 0 1: x1/2<br>0 1 0: x1/4<br>0 1 1: x1/8<br>1 0 0: x1/16<br>Settings other than above are prohibited.        | R/W |
| b15        | CKOSTP      | CLKOUT Output Stop Control             | 0: CLKOUT pin output enabled*1 1: CLKOUT pin output disabled                                                                                  | R/W |

Note: Set the PRCR.PRC0 bit to 1 (write enabled) before rewriting this register.

Note 1. It is also necessary to set the pin function control register and port mode register for the corresponding pin.

### CKOSEL[2:0] Bits (CLKOUT Output Source Select)

Set these bits to select the LOCO clock, HOCO clock, main clock, or sub-clock as the source of the clock to be output from the CLKOUT pin.

### CKODIV[2:0] Bits (CLKOUT Output Division Ratio Select)

Set these bits to select the clock division ratio.

Set the CKOSTP bit to 1 when changing the division ratio.

The division ratio of the output clock frequency should be set to no higher than 8 MHz when VCC is 2.7 V or above, and no higher than 4 MHz when VCC is below 2.7 V.

For details on the characteristics of the clock output from the CLKOUT pin, see Table 32.30, Timing of On-Chip Peripheral Modules (1).

### **CKOSTP Bit (CLKOUT Output Stop Control)**

Set this bit to enable or disable output from the CLKOUT pin.

When this bit is set to 1, the selected clock is output. When this bit is set to 1, a low level is output.

If the CKOSTP bit is rewritten while the clock is still oscillating, a glitch may be generated in the output.

# 9.2.14 Main Clock Oscillator Forced Oscillation Control Register (MOFCR)

Address(es): 0008 C293h



| Bit      | Symbol  | Bit Name                                         | Description                                                                                            | R/W |
|----------|---------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | _       | Reserved                                         | These bits are read as 0. The write value should be 0.                                                 | R/W |
| b5       | MODRV21 | Main Clock Oscillator Drive<br>Capability Switch | VCC ≥ 2.4 V 0: 1 MHz to 10 MHz 1: 10 MHz to 20 MHz VCC < 2.4 V 0: 1 MHz to 8 MHz 1: Setting prohibited | R/W |
| b6       | MOSEL   | Main Clock Oscillator Switch                     | 0: Resonator<br>1: External oscillator input                                                           | R/W |
| b7       | _       | Reserved                                         | This bit is read as 0. The write value should be 0.                                                    | R/W |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

## **MODRV21 Bit (Main Clock Oscillator Drive Capability Switch)**

These bits select the drive capability of the main clock oscillator.

# **MOSEL Bit (Main Clock Oscillator Switch)**

This bit selects the oscillation source of the main clock oscillator.

### 9.3 Main Clock Oscillator

There are two ways of supplying the clock signal from the main clock oscillator: connecting an oscillator or the input of an external clock signal.

## 9.3.1 Connecting a Crystal

Figure 9.2 shows an example of connecting a crystal.

A damping resistor (Rd) should be added, if necessary. Since the resistor values vary depending on the resonator and the oscillation drive capability, use values recommended by the resonator manufacturer. If use of an external feedback resistor (Rf) is directed by the resonator manufacturer, insert an Rf between EXTAL and XTAL by following the instruction.

When connecting a resonator to supply the clock, the frequency of the resonator should be in the frequency range of the resonator for the main clock oscillator described in Table 9.1.



Figure 9.2 Example of Crystal Connection

Table 9.3 Damping Resistance (Reference Values)

| Frequency (MHz) | 2 | 8 | 16 | 20 |
|-----------------|---|---|----|----|
| Rd (Ω)          | 0 | 0 | 0  | 0  |

Figure 9.3 shows an equivalent circuit of the crystal. Use a crystal that has the characteristics shown in Table 9.4 as a reference.



Figure 9.3 Equivalent Circuit of Crystal

Table 9.4 Crystal Characteristics (Reference Values)

| Frequency (MHz)         | 8   | 12  | 16  |  |
|-------------------------|-----|-----|-----|--|
| R <sub>S</sub> max (Ω)  | 200 | 120 | 56  |  |
| C <sub>0</sub> max (pF) | 1.3 | 1.3 | 1.4 |  |

# 9.3.2 External Clock Input

Figure 9.4 shows connection of an external clock. Set the MOFCR.MOSEL bit to 1 if operation is to be driven by an external clock. In this case, the EXTAL pin will be in the Hi-Z state.



Figure 9.4 Connection Example of External Clock

# 9.3.3 Handling of Pins When the Main Clock is Not Used

For details on pin handling when the main clock is not used, refer to section 17.5, Handling of Unused Pins.

## 9.3.4 Notes on the External Clock Input

The frequency of the external clock input can only be changed while the main clock oscillator is stopped. Do not change the frequency of the external clock input while the setting of the main clock oscillator stop bit (MOSCCR.MOSTP) is 0 (main clock oscillator is operating).

### 9.4 Sub-Clock Oscillator

The only way of supplying the clock signal from the sub-clock oscillator is connecting a crystal.

## 9.4.1 Connecting 32.768-kHz Crystal

To supply a clock to the sub-clock oscillator, connect a 32.768-kHz crystal, as shown in Figure 9.5.

A damping resistor Rd should be added, if necessary. Since the resistor values vary depending on the resonator and the oscillation drive capability, use values recommended by the resonator manufacturer. If use of an external feedback resistor (Rf) is directed by the resonator manufacturer, insert an Rf between XCIN and XCOUT by following the instruction. When connecting a resonator to supply the clock, the frequency of the resonator should be in the frequency range of the resonator for the sub-clock oscillator described in Table 9.1.



Figure 9.5 Connection Example of 32.768-kHz Crystal

Figure 9.6 shows an equivalent circuit for the 32.768-kHz crystal. Use a crystal that has the characteristics listed in Table 9.5.



Figure 9.6 Equivalent Circuit for Crystal

Table 9.5 Crystal Characteristics (Reference Values)

| Frequency (kHz)         | 32.768 (Low CL) |  |
|-------------------------|-----------------|--|
| R <sub>S</sub> max (kΩ) | 37              |  |
| C <sub>0</sub> max (pF) | 0.9             |  |

### 9.4.2 Handling of Pins When Sub-Clock is Not Used

When the sub-clock is not used, set the SOSCCR.SOSTP bit to 1 (stopped) and set the RCR3.RTCEN bit to 0 (sub-clock oscillator is stopped) (set general port PH7). When this pin is not also used as port PH7, handle it as an unused pin. For handling of unused pins, refer to section 18.5, Handling of Unused Pins.

### 9.5 Oscillation Stop Detection Function

### 9.5.1 Oscillation Stop Detection and Operation after Detection

The oscillation stop detection function is used to detect the main clock oscillator stop and to supply LOCO clock pulses from the low-speed on-chip oscillator as the system clock source instead of the main clock.

An oscillation stop detection interrupt request can be generated when an oscillation stop is detected. In addition, the MTU output can be forcedly driven to the high-impedance on the detection. For details, refer to section 19, Multi-Function Timer Pulse Unit 2 (MTU2b).

In the MCU, the main clock oscillation stop is detected when the input clock remains to be 0 or 1 for a certain period, for example, due to a malfunction of the main clock oscillator (refer to Table 32.43, Oscillation Stop Detection Circuit Characteristics, in section 32, Electrical Characteristics).

When an oscillation stop is detected, the main clock selected by the clock source select bits (SCKCR3.CKSEL[2:0]) is switched to the LOCO clock by the corresponding selectors in the former stage. Therefore, if an oscillation stop is detected with the main clock selected as the system clock source, the system clock source is switched to the LOCO clock without a change of CKSEL[2:0].

Switching between the main clock and LOCO clock is controlled by the oscillation stop detection flag (OSTDSR.OSTDF). The clock source is switched to the LOCO clock when the OSTDF flag is 1, and is switched to the main clock again when the OSTDF flag is set to 0. At this time, if the main clock is selected with the CKSEL[2:0] bits, the OSTDF flag cannot be set to 0. To switch the clock source to the main clock again after the oscillation stop detection, set the CKSEL[2:0] bits to a clock source other than the main clock and set the OSTDF flag to 0. After that, check that the OSTDF flag is not 1, and then set the CKSEL[2:0] bits to the main clock after the specified oscillation stabilization time has elapsed.

After a reset is released, the main clock oscillator is stopped and the oscillation stop detection function is disabled. To enable the oscillation stop detection function, activate the main clock oscillator and write 1 to the oscillation stop detection function enable bit (OSTDCR.OSTDE) after a specified oscillation stabilization time has elapsed. The oscillation stop detection function is provided against the main clock stop by an external cause. Therefore, the oscillation stop detection function should be disabled before the main clock oscillator is stopped by the software or a transition is made to software standby mode.

When the main clock or CAC main clock (CACMCLK) is selected as the system clock source, these clocks are switched to the LOCO clock by the oscillation stop detection. The system clock (ICLK) frequency during the LOCO clock operation is specified by the LOCO oscillation frequency and the division ratio set by the system clock (ICLK) select bits (SCKCR.ICK[3:0]).



Figure 9.7 Flow of Recovery from Detection of Oscillator Stop

# 9.5.2 Oscillation Stop Detection Interrupts

An oscillation-stop detection interrupt (OSTDI) will be generated if the oscillation-stop detection flag (OSTDSR.OSTDF) becomes 1 while the oscillation-stop detection interrupt enable bit (OSTDCR.OSTDIE) is 1 (oscillation stop detection interrupt enabled). When the OSTDSR.OSTDF flag requires clearing, do so setting the oscillation stop detection interrupt enable bit (OSTDCR.OSTDIE) to 0. Wait for at least two cycles of PCLKB clock before again setting the OSTDCR.OSTDIE bit to 1. According to the number of cycles for access to read a given I/O register, wait time longer than two cycles of PCLKB may have to be secured.

The oscillation stop detection interrupt is a non-maskable interrupt. Since non-maskable interrupts are disabled in the initial state after a reset release, enable the non-maskable interrupts by the software before using oscillation stop detection interrupts. For details, refer to section 14, Interrupt Controller (ICUb).

#### 9.6 Internal Clock

Clock sources of internal clock signals are the main clock, sub-clock, HOCO clock, LOCO clock, and dedicated low-speed clock for the IWDT. The internal clocks listed below are produced from these sources.

- (1) Operating clock of the CPU, DTC, ROM, and RAM: System clock (ICLK)
- (2) Operating clock of peripheral modules: Peripheral module clock (PCLKB and PCLKD)
- (3) Operating clock of the FlashIF: FlashIF clock (FCLK)
- (4) Operating clock for the CAC: CAC clock (CACCLK)
- (5) Operating clock for the RTC: RTC-dedicated sub-clock (RTCSCLK)
- (6) Operating clock for the IWDT: IWDT-dedicated low-speed clock (IWDTCLK)

Frequencies of the internal clocks are set by the combination of the divisors selected by the SCKCR.FCK[3:0], ICK[3:0], PCKB[3:0], and PCKD[3:0] bits, and the clock source selected by the SCKCR3.CKSEL[2:0] bits. If the value of any of these bits is changed, subsequent operation will be at the frequency determined by the new value.

### 9.6.1 System Clock

The system clock (ICLK) is used as the operating clock of the CPU, DTC, ROM, and RAM.

The ICLK frequency is specified by the SCKCR.ICK[3:0] bits and the SCKCR3.CKSEL[2:0] bits.

### 9.6.2 Peripheral Module Clock

The peripheral module clocks (PCLKB and PCLKD) are the operating clocks for use by peripheral modules. The PCLKB and PCLKD frequencies are specified by the SCKCR.PCKB[3:0] and PCKD[3:0] bits, and the

SCKCR3.CKSEL[2:0] bits.

The peripheral module clock used as the operating clock is PCLKD for S12AD and PCLKB for other modules.

### 9.6.3 FlashIF Clock

The FlashIF clock (FCLK) is used as the operating clock of the FlashIF.

The FCLK frequency is specified by the SCKCR.FCK[3:0] bits and the SCKCR3.CKSEL[2:0] bits.

#### 9.6.4 CAC Clock

The CAC clock (CACCLK) is an operating clock for the CAC module.

The CACCLK clocks include CACMCLK which is generated by the main clock oscillator, CACSCLK which is generated by the sub-clock oscillator, CACHCLK which is generated by the high-speed on-chip oscillator, CACLCLK which is generated by the low-speed on-chip oscillator, and CACILCLK which is generated by the IWDT-dedicated on-chip oscillator.

### 9.6.5 RTC-Dedicated Clock

The RTC-dedicated clock (RTCSCLK) is the operating clock for the RTC.

RTCSCLK is generated by the sub-clock oscillator.

### 9.6.6 IWDT-Dedicated Clock

The IWDT-dedicated clock (IWDTCLK) is the operating clock for the IWDT. IWDTCLK is internally generated by the IWDT-dedicated on-chip oscillator.



# 9.7 Usage Notes

### 9.7.1 Notes on Clock Generation Circuit

(1) The frequencies of the system clock (ICLK), peripheral module clocks (PCLKB and PCLKD), and FlashIF clock (FCLK) supplied to each module change according to the settings of the SCKCR register. Each frequency should meet the following:

Select each frequency that is within the operation guaranteed range of clock cycle time (tcyc) specified in AC characteristics of electrical characteristics.

The frequencies must not exceed the ranges listed in Table 9.1.

The peripheral modules operate on the PCLKB and PCLKD. Note therefore that the operating speed of modules such as the timer and SCI varies before and after the frequency is changed.

- (2) The relationship of frequencies of the system clock (ICLK), peripheral module clocks B and D (PCLKB and PCLKD), and FlashIF clock (FCLK) must be set as follows.
  - ICLK: FCLK, PCLKB, and PCLKD = N: 1 (N is an integer)
- (3) To secure the processing after the clock frequency is changed, modify the pertinent clock control register to change the frequency, and then read the value from the register, and then perform the subsequent processing.

#### 9.7.2 Notes on Resonator

Since various resonator characteristics relate closely to the user's board design, adequate evaluation is required on the user side before use, referencing the resonator connection example shown in this section. The circuit constants for the resonator depend on the resonator to be used and the stray capacitance of the mounting circuit. Therefore, the circuit constants should be determined in full consultation with the resonator manufacturer. The voltage to be applied between the resonator pins must be within the absolute maximum rating.

### 9.7.3 Notes on Board Design

When using a crystal, place the resonator and its load capacitors as close to the XTAL and EXTAL pins as possible. Other signal lines should be routed away from the oscillation circuit as shown in Figure 9.8 to prevent electromagnetic induction from interfering with correct oscillation.



Figure 9.8 Notes on Board Design for Oscillation Circuit (Applies to the Sub-Clock Oscillator, in Case of the Main Clock Oscillator)

#### 9.7.4 Notes on Sub-Clock

The sub-clock can be used as the system clock, as the count source for the realtime clock, or as both. Take note of the following limitations and points for caution regarding the settings, including when the sub-clock is not in use.

- With regard to making the sub-clock oscillator run or stop, setting either the sub-clock oscillator stop bit in the sub-clock oscillator control register (SOSCCR.SOSTP) or the sub-clock oscillator control bit in RTC control register 3 (RCR3.RTCEN) will make the oscillator run.
- To use the sub-clock as the system clock and as the count source of the realtime clock simultaneously, perform initial settings according to the flowchart example shown in Figure 9.9. After that, perform the clock setting procedure shown in section 21.3.2, Clock and Count Mode Setting Procedure.



Figure 9.9 Example of Initialization Flowchart When Sub-Clock is Used as Count Source of Realtime Clock

• When using the sub-clock only as the count source of the realtime clock, perform initial settings according to the flowchart example shown in Figure 9.10. After that, perform the clock setting procedure shown in section 21.3.2, Clock and Count Mode Setting Procedure.



Figure 9.10 Example of Initialization Flowchart When Sub-Clock is Used Only as Count Source of Realtime Clock

• When using the sub-clock only as the system clock, perform initial settings according to the flowchart example shown in Figure 9.11.



Figure 9.11 Example of Initialization Flowchart When Sub-Clock is Used Only as System Clock

• When not using the sub-clock, perform initial settings according to the flowchart example in Figure 9.12.



Figure 9.12 Example of Initialization Flowchart When Sub-Clock is Not Used

- Regardless of the RCR3.RTCEN bit setting, wait until the oscillator stabilization wait time elapses before rewriting the SOSCCR.SOSTP bit to 0 (sub-clock oscillator is operating).
- Since the sub-clock control circuit is in an unstable state after a cold start, it must be initialized regardless of
  whether or not the sub-clock is in use. The sub-clock is initialized by setting the SOSCCR.SOSTP bit to 1 and the
  RCR3.RTCEN bit to 0 (sub-clock oscillator is stopped). See section 21.2.19, RTC Control Register 3 (RCR3),
  for instructions to initialize the RCR3.RTCEN bit.
   Although the sub-clock oscillator pins are not available in 40 or fewer pin package products, initialize the sub-clock
- The RCR3.RTCDV[2:0] bits must also be set when operating the sub-clock oscillator. Set these bits while the sub-clock oscillator is stopped. Do not rewrite these bits while the sub-clock oscillator is operating.
- When successively rewriting the SOSCCR.SOSTP bit followed by the RCR3.RTCEN bit or vice versa, confirm that the first bit rewrite was completed successfully before rewriting the second bit.

control circuit in the same way.

# 10. Clock Frequency Accuracy Measurement Circuit (CAC)

### 10.1 Overview

The clock frequency accuracy measurement circuit (CAC) counts pulses of the clock to be measured (measurement target clock) within the time generated by the clock to be used as a measurement reference (measurement reference clock), and determines the accuracy depending on whether the number of pulses is within the allowable range. When measurement is completed or the number of pulses within the time generated by the measurement reference clock is not within the allowable range, an interrupt request is generated.

Table 10.1 lists the specifications of the CAC and Figure 10.1 shows a block diagram of the CAC.

Table 10.1 CAC Specifications

| Item                           | Description                                            |
|--------------------------------|--------------------------------------------------------|
| Measurement target clocks      | The frequency of the following clocks can be measured. |
|                                | Main clock                                             |
|                                | • Sub-clock                                            |
|                                | HOCO clock                                             |
|                                | LOCO clock                                             |
|                                | IWDTCLK clock                                          |
|                                | Peripheral module clock B (PCLKB)                      |
| Measurement reference clocks   | External clock input to the CACREF pin                 |
|                                | Main clock                                             |
|                                | • Sub-clock                                            |
|                                | HOCO clock                                             |
|                                | LOCO clock                                             |
|                                | IWDTCLK clock                                          |
|                                | <ul> <li>Peripheral module clock B (PCLKB)</li> </ul>  |
| Selectable function            | Digital filter function                                |
| Interrupt sources              | Measurement end interrupt                              |
|                                | Frequency error interrupt                              |
|                                | Overflow interrupt                                     |
| Low power consumption function | Module stop state can be set.                          |



Figure 10.1 CAC Block Diagram

Table 10.2 shows the pin configuration of the CAC.

Table 10.2 Pin Configuration of CAC

| Pin Name | I/O   | Function                              |  |
|----------|-------|---------------------------------------|--|
| CACREF   | Input | Measurement reference clock input pin |  |

# 10.2 Register Descriptions

# 10.2.1 CAC Control Register 0 (CACR0)

Address(es): 0008 B000h



| Bit      | Symbol | Bit Name                           | Description                                                                          | R/W |
|----------|--------|------------------------------------|--------------------------------------------------------------------------------------|-----|
| b0       | CFME   | Clock Frequency Measurement Enable | Clock frequency measurement is disabled.     Clock frequency measurement is enabled. | R/W |
| b7 to b1 | _      | Reserved                           | These bits are read as 0. The write value should be 0.                               | R/W |

### **CFME Bit (Clock Frequency Measurement Enable)**

This bit specifies whether clock frequency measurement is enabled or disabled.

When rewriting this bit, more time is required than other bits for the new value to be reflected in the register. Further write access to this bit are ignored until the current write access is reflected in the register. Read the bit to confirm that the rewrite has been reflected in the register.

# 10.2.2 CAC Control Register 1 (CACR1)

Address(es): 0008 B001h



| Bit      | Symbol     | Bit Name                        | Description                                                                                                                                                                          | R/W |
|----------|------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | CACREFE    | CACREF Pin Input Enable         | CACREF pin input is disabled.     CACREF pin input is enabled.                                                                                                                       | R/W |
| b3 to b1 | FMCS[2:0]  | Measurement Target Clock Select | b3 b1 0 0 0: Main clock 0 0 1: Sub-clock 0 1 0: HOCO clock 0 1 1: LOCO clock 1 0 0: IWDTCLK clock 1 0 1: Peripheral module clock B (PCLKB) Settings other than above are prohibited. | R/W |
| b5, b4   | TCSS[1:0]  | Timer Count Clock Source Select | b5 b4<br>0 0: No division<br>0 1: x1/4 clock<br>1 0: x1/8 clock<br>1 1: x1/32 clock                                                                                                  | R/W |
| b7, b6   | EDGES[1:0] | Valid Edge Select               | b7 b6 0 0: Rising edge 0 1: Falling edge 1 0: Both rising and falling edges 1 1: Setting prohibited                                                                                  | R/W |

Note 1. Set the CACR1 register when the CACR0.CFME bit is 0.

### **CACREFE Bit (CACREF Pin Input Enable)**

This bit specifies whether the CACREF pin input is enabled or disabled.

### FMCS[2:0]Bits (Measurement Target Clock Select)

These bits select the measurement target clock whose frequency is to be measured.

## TCSS[1:0] Bits (Timer Count Clock Source Select)

These bits select the count clock source for the clock frequency accuracy measurement circuit.

## EDGES[1:0]Bits (Valid Edge Select)

These bits select the valid edge for the reference signal.

# 10.2.3 CAC Control Register 2 (CACR2)

Address(es): 0008 B002h



| Bit      | Symbol                         | Bit Name                                                        | Description                                                                                                                                                                                                                                                                                                                                                                     | R/W |
|----------|--------------------------------|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | b0 RPS Reference Signal Select |                                                                 | CACREF pin input     Internal clock (internally generated signal)                                                                                                                                                                                                                                                                                                               |     |
| b3 to b1 | RSCS[2:0]                      | Measurement Reference Clock<br>Select                           | b3 b1 0 0 0: Main clock 0 0 1: Sub-clock 0 1 0: HOCO clock 0 1 1: LOCO clock 1 0 0: IWDTCLK clock 1 0 1: Peripheral module clock B (PCLKB) Settings other than above are prohibited.                                                                                                                                                                                            | R/W |
| b5, b4   | RCDS[1:0]                      | Measurement Reference Clock<br>Frequency Division Ration Select | b5 b4<br>0 0: ×1/32 clock<br>0 1: ×1/128 clock<br>1 0: ×1/1024 clock<br>1 1: ×1/8192 clock                                                                                                                                                                                                                                                                                      | R/W |
| b7, b6   | DFS[1:0]                       | Digital Filter Select                                           | <ul> <li>b7 b6</li> <li>0 0: Digital filtering is disabled.</li> <li>0 1: The sampling clock for the digital filter is the frequency measuring clock.</li> <li>1 0: The sampling clock for the digital filter is the frequency measuring clock divided by 4.</li> <li>1 1: The sampling clock for the digital filter is the frequency measuring clock divided by 16.</li> </ul> | R/W |

Note 1. Set the CACR2 register when the CACR0.CFME bit is 0.

## **RPS Bit (Reference Signal Select)**

This bit selects whether to use the CACREF pin input or an internal clock (internally generated signal) as the reference signal.

### RSCS[2:0]Bits (Measurement Reference Clock Select)

These bits select the clock source for generating the measurement reference clock.

### RCDS[1:0]Bits (Measurement Reference Clock Frequency Division Ration Select)

These bits select the frequency division ratio of the measurement reference clock.

### DFS[1:0]Bits (Digital Filter Select)

The setting of these bits enables or disables the digital filter and selects its sampling clock.

# 10.2.4 CAC Interrupt Request Enable Register (CAICR)

Address(es): 0008 B003h



| Bit | Symbol  | Bit Name                                    | Description                                                                                      | R/W |
|-----|---------|---------------------------------------------|--------------------------------------------------------------------------------------------------|-----|
| b0  | FERRIE  | Frequency Error Interrupt Request<br>Enable | Frequency error interrupt request is disabled.     Frequency error interrupt request is enabled. | R/W |
| b1  | MENDIE  | Measurement End Interrupt<br>Request Enable | Measurement end interrupt request is disabled.     Measurement end interrupt request is enabled. | R/W |
| b2  | OVFIE   | Overflow Interrupt Request Enable           | Overflow interrupt request is disabled.     Overflow interrupt request is enabled.               | R/W |
| b3  | _       | Reserved                                    | This bit is read as 0. The write value should be 0.                                              | R/W |
| b4  | FERRFCL | FERRF Clear                                 | When 1 is written to this bit, the CASTR.FERRF flag is cleared. This bit is read as 0.           | R/W |
| b5  | MENDFCL | MENDF Clear                                 | When 1 is written to this bit, the CASTR.MENDF flag is cleared. This bit is read as 0.           | R/W |
| b6  | OVFFCL  | OVFF Clear                                  | When 1 is written to this bit, the CASTR.OVFF flag is cleared. This bit is read as 0.            | R/W |
| b7  | _       | Reserved                                    | This bit is read as 0. The write value should be 0.                                              | R/W |

### **FERRIE Bit (Frequency Error Interrupt Request Enable)**

This bit specifies whether the frequency error interrupt request is enabled or disabled.

### **MENDIE Bit (Measurement End Interrupt Request Enable)**

This bit specifies whether the measurement end interrupt request is enabled or disabled.

### **OVFIE Bit (Overflow Interrupt Request Enable)**

This bit specifies whether the overflow interrupt request is enabled or disabled.

### FERRFCL Bit (FERRF Clear)

Setting this bit to 1 clears the CASTR.FERRF flag.

### **MENDFCL Bit (MENDF Clear)**

Setting this bit to 1 clears the CASTR.MENDF flag.

### **OVFFCL Bit (OVFF Clear)**

Setting this bit to 1 clears the CASTR.OVFF flag.

# 10.2.5 CAC Status Register (CASTR)

Address(es): 0008 B004h



| Bit      | Symbol | Bit Name             | Description                                                                                                                                                                      | R/W |
|----------|--------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | FERRF  | Frequency Error Flag | O: The clock frequency is within the range corresponding to the settings.  1: The clock frequency has deviated beyond the range corresponding to the settings (frequency error). | R   |
| b1       | MENDF  | Measurement End Flag | Measurement is in progress.     Measurement has ended.                                                                                                                           | R   |
| b2       | OVFF   | Overflow Flag        | O: The counter has not overflowed. T: The counter has overflowed.                                                                                                                | R   |
| b7 to b3 | _      | Reserved             | These bits are read as 0. The write value should be 0.                                                                                                                           | R/W |

### **FERRF Flag (Frequency Error Flag)**

This flag indicates deviation of the clock frequency from the set value (frequency error). [Setting condition]

• The clock frequency is outside of the setting range.

[Clearing condition]

• 1 is written to the CAICR.FERRFCL bit.

### **MENDF Flag (Measurement End Flag)**

This flag indicates the end of measurement.

[Setting condition]

• Measurement has finished.

[Clearing condition]

• 1 is written to the CAICR.MENDFCL bit.

### **OVFF Flag (Overflow Flag)**

This flag indicates that the counter has overflowed.

[Setting condition]

• The counter has overflowed.

[Clearing condition]

• 1 is written to the CAICR.OVFFCL bit.

# 10.2.6 CAC Upper-Limit Value Setting Register (CAULVR)

Address(es): 0008 B006h



CAULVR is a 16-bit readable/writable register that specifies the upper-limit value of the counter used for measuring the frequency. When the frequency rises above the value specified in this register, a frequency error is detected. Write to this register when the CACRO.CFME bit is 0.

The counter value held in CACNTBR can vary with the difference between the phases of the digital filter and edgedetection circuit on the one hand and the signal on the CACREF pin on the other, so ensure that this setting allows an adequate margin.

# 10.2.7 CAC Lower-Limit Value Setting Register (CALLVR)

Address(es): 0008 B008h



CALLVR is a 16-bit readable/writable register that specifies the lower-limit value of the counter used for measuring the frequency. When the frequency falls below the value specified in this register, a frequency error is detected. Write to this register when the CACRO.CFME bit is 0.

The counter value held in CACNTBR can vary with the difference between the phases of the digital filter and edgedetection circuit on the one hand and the signal on the CACREF pin on the other, so ensure that this setting allows an adequate margin.

# 10.2.8 CAC Counter Buffer Register (CACNTBR)

Address(es): 0008 B00Ah



CACNTBR is a 16-bit read-only register that retains the counter value at the time a valid reference signal edge is input.

## 10.3 Operation

# 10.3.1 Measuring Clock Frequency

The clock frequency accuracy measurement circuit measures the clock frequency using the CACREF pin input or the internal clock as a reference. Figure 10.2 shows an operating example of the clock frequency accuracy measurement circuit.

The clock frequency accuracy measurement circuit operates as shown below when measuring the clock frequency.



Figure 10.2 Operating Example of Clock Frequency Accuracy Measurement Circuit

- (1) When the CACREF pin input is used as a reference (CACR1.CACREFE bit = 1), clock frequency measurement is enabled by writing 1 to the CACR0.CFME bit while the CACR2.RPS bit is 0 and the CACR1.CACREFE bit is 1. On the other hand, when the internal clock is used as a reference (CACR1.CACREFE bit = 0), clock frequency measurement is enabled by writing 1 to the CACR0.CFME bit while the CACR2.RPS bit is 1.
- (2) When the CACREF pin input is used as a reference, the timer starts up-counting if the valid edge selected by the CACR1.EDGES[1:0] bits is input from the CACREF pin after 1 is written to the CFME bit. The valid edge is a rising edge (CACR1.EDGES[1:0] = 00b) in Figure 10.2.
  When the internal clock is used as a reference, the timer starts up-counting if the valid edge selected by the CACR1.EDGES[1:0] bits is input based on the clock source selected by the CACR2.RSCS[2:0] bits after 1 is written to the CFME bit. The valid edge is a rising edge (CACR1.EDGES[1:0] = 00b) in Figure 10.2.
- (3) When the next valid edge is input, the counter value is transferred in CACNTBR and compared with the values of CAULVR and CALLVR. If both CACNTBR ≤ CAULVR and CACNTBR ≥ CALLVR are satisfied, only the MENDF flag in CASTR is set to 1 because the clock frequency is correct. If the MENDIE bit in CAICR is 1, a measurement end interrupt is generated.
- (4) When the next valid edge is input, the counter value is transferred in CACNTBR and compared with the values of CAULVR and CALLVR. In the case of CACNTBR > CAULVR, the FERRF flag in CASTR is set to 1 because the

- clock frequency is erroneous. If the FERRIE bit in CAICR is 1, a frequency error interrupt is generated. Also, the MENDF flag in CASTR is set to 1. If the MENDIE bit in CAICR is 1, a measurement end interrupt is generated.
- (5) When the next valid edge is input, the counter value is transferred in CACNTBR and compared with the values of CAULVR and CALLVR. In the case of CACNTBR < CALLVR, the FERRF flag in CASTR is set to 1 because the clock frequency is erroneous. If the FERRIE bit in CAICR is 1, a frequency error interrupt is generated. Also, the MENDF flag in CASTR is set to 1. If the MENDIE bit in CAICR is 1, a measurement end interrupt is generated.
- (6) While the CFME bit in CACR0 is 1, the counter value is transferred in CACNTBR and compared with the values of CAULVR and CALLVR every time a valid edge is input. Writing 0 to the CFME bit in CACR0 clears the counter and stops up-counting.

### 10.3.2 Digital Filtering of Signals on the CACREF Pin

The CACREF pin has a digital filter. Levels on the target pin for sampling are conveyed to the internal circuitry after matching three consecutive times at the selected sampling interval and the same level continues to be conveyed internally until the level on the pin again matches three consecutive times.

Enabling and disabling of the digital filter and its sampling clock are selectable.

The counter value transferred in CACNTBR may be in error by up to one cycle of the sampling clock due to the difference between the phases of the digital filter and the signal input to the CACREF pin.

When a frequency dividing clock is selected as a count source clock, the counter value error is obtained by the following formula:

Counter value error = (One cycle of the count source clock) / (One cycle of the sampling clock)

### 10.4 Interrupt Requests

The CAC generates three types of interrupt request: frequency error interrupt, measurement end interrupt, and overflow interrupt. When an interrupt source is generated, the corresponding status flag becomes 1. Table 10.3 lists details on the interrupt requests of the clock frequency accuracy measurement circuit.

Table 10.3 Interrupt Requests of Clock Frequency Accuracy Measurement Circuit

| Interrupt Request         | Interrupt Enable Bit | Status Flag | Interrupt Source                                                                                                                                                        |
|---------------------------|----------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Frequency error interrupt | CAICR.FERRIE         | CASTR.FERRF | The result of comparing CACNTBR to CAULVR and CALLVR is either CACNTBR > CAULVR or CACNTBR < CALLVR.                                                                    |
| Measurement end interrupt | CAICR.MENDIE         | CASTR.MENDF | A valid edge is input from the CACREF pin.  Note however that a measurement end interrupt does not occur at the first valid edge after writing 1 to the CACR0.CFME bit. |
| Overflow interrupt        | CAICR.OVFIE          | CASTR.OVFF  | The counter has overflowed.                                                                                                                                             |

# 10.5 Usage Notes

# 10.5.1 Module Stop Function Setting

CAC operation can be disabled or enabled using module stop control register C (MSTPCRC). The initial setting is for the CAC to be halted. Register access is enabled by releasing the module stop state. For details, refer to section 11, Low Power Consumption.

# 11. Low Power Consumption

### 11.1 Overview

This MCU has several functions for reducing power consumption, by setting clock dividers, stopping modules, changing to low power consumption mode in normal operation, and changing to operating power control mode.

Table 11.1 lists the specifications of low power consumption functions, and Table 11.2 lists the conditions to change to low power consumption modes, states of the CPU and peripheral modules, and the method for exiting each mode. After a reset, this MCU returns to normal mode, but modules except the DTC and RAM are stopped.

Table 11.1 Specifications of Low Power Consumption Functions

| Item                          | Specification                                                                                                                                                                                                                                                                                                                                   |  |  |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Clock divider functions       | The frequency division ratio can be set independently for the system clock (ICLK), peripheral module clock (PCLKB), S12AD clock (PCLKD), and FlashIF clock (FCLK).*1                                                                                                                                                                            |  |  |
| Module stop function          | Each peripheral module can be stopped independently by the module stop control register.                                                                                                                                                                                                                                                        |  |  |
| Low power consumption modes   | Power consumption can be reduced by selecting an appropriate power consumption mode according to which module is need to operate.*2  Three low power consumption modes are available.*3  • Sleep mode  • Deep sleep mode  • Software standby mode                                                                                               |  |  |
| Operating power control modes | Power consumption can be reduced in normal operation, sleep mode, and deep sleep mode by selecting an appropriate operating power control mode according to the operating frequency and operating voltage.  Three operating power control modes are available  High-speed operating mode  Middle-speed operating mode  Low-speed operating mode |  |  |

Note 1. For details, refer to section 9, Clock Generation Circuit.

Note 2. For details, refer to section 11.6, Low Power Consumption Modes.

Note 3. For details, refer to Figure 11.2, Operating Conditions of Each Power Consumption Mode.

Table 11.2 Operating Conditions of Each Power Consumption Mode

|                                                 | Sleep Mode                     | Deep Sleep Mode                | Software Standby Mode          |
|-------------------------------------------------|--------------------------------|--------------------------------|--------------------------------|
| Entry trigger                                   | Control register + instruction | Control register + instruction | Control register + instruction |
| Exit trigger                                    | Interrupt                      | Interrupt                      | Interrupt*1                    |
| After exiting from each mode, CPU begins from*2 | Interrupt handling             | Interrupt handling             | Interrupt handling             |
| Main clock oscillator                           | Operating possible             | Operating possible             | Stopped                        |
| Sub-clock oscillator                            | Operating possible             | Operating possible             | Operating possible             |
| High-speed on-chip oscillator                   | Operating possible             | Operating possible             | Stopped                        |
| Low-speed on-chip oscillator                    | Operating possible             | Operating possible             | Stopped                        |
| IWDT-dedicated on-chip oscillator               | Operating possible*3           | Operating possible*3           | Operating possible*3           |
| CPU                                             | Stopped (Retained)             | Stopped (Retained)             | Stopped (Retained)             |
| RAM0 (0000 0000h to 0000 3FFFh)                 | Operating possible (Retained)  | Stopped (Retained)             | Stopped (Retained)             |
| DTC                                             | Operating possible*5           | Stopped (Retained)             | Stopped (Retained)             |
| Flash memory                                    | Operating                      | Stopped (Retained)             | Stopped (Retained)             |
| Independent watchdog timer (IWDT)               | Operating possible*3           | Operating possible*3           | Operating possible*3           |
| Realtime clock (RTC)                            | Operating possible             | Operating possible             | Operating possible             |
| Voltage detection circuit (LVD)                 | Operating possible             | Operating possible             | Operating possible             |
| Power-on reset circuit                          | Operating                      | Operating                      | Operating                      |
| Peripheral modules                              | Operating possible             | Operating possible             | Stopped (Retained)*4           |
| I/O ports                                       | Operating                      | Operating                      | Retained                       |
| RTCOUT                                          | Operating possible             | Operating possible             | Operating possible             |
| CLKOUT                                          | Operating possible             | Operating possible             | Operating possible*6           |

<sup>&</sup>quot;Operating possible" means that operating or stopped can be controlled by the register setting.

- Note 1. "Interrupts" here indicates an external pin interrupt (the NMI or IRQ0 to IRQ7) or any of peripheral interrupts (the RTC alarm, RTC interval, IWDT, and voltage monitoring interrupts).
- Note 2. This does not include a RES# pin reset, power-on reset, voltage monitoring reset, or independent watchdog-timer reset. One of these reset sources initiate transition to reset state.
- Note 3. Operating or stopping is selected by setting the IWDT sleep mode count stop control bit (IWDTSLCSTP) in option function select register 0 (OFS0) in IWDT auto-start mode. In any mode other than IWDT auto-start mode, operating or stopping is selected by the setting of the sleep mode count stop control bit (SLCSTP) in the IWDT count stop control register (IWDTCSTPR).
- Note 4. The peripheral logic states are retained.
- Note 5. During sleep mode, do not write to the system control related registers (indicated by 'SYSTEM' in the Module Symbol column in Table 5.1, List of I/O Registers (Address Order).
- Note 6. Stopped when the clock output source select bits (CKOCR.CKOSEL[2:0]) are set to a value other than 011b (sub-clock oscillator).

<sup>&</sup>quot;Stopped (Retained)" means that internal register values are retained and internal operations are suspended.



- Note 1. If an interrupt is accepted while entering low power consumption mode, the transition to the program stop state is exited and the interrupt exception handling is executed.
- Note 2. "Interrupts" here indicates an external pin interrupt (the NMI or IRQ0 to IRQ7) or any of peripheral interrupts (the RTC alarm, RTC interval, IWDT, and voltage monitoring interrupts).
- Note 3. The LOCO is the clock source following a transition from the reset state to normal mode.
- Note 4. Makes a transition from sleep mode, deep sleep mode, or software standby mode to normal operating mode by an interrupt. In the case of exiting sleep mode, the clock source after exiting is selectable. For details, refer to the description of the RSTCKCR register.

For deep sleep mode and software standby mode, the clock source after exiting is the same as that of the clock before entering software standby mode.

Transition to the reset state is made at any state instantly after a RES# pin reset, power on reset, voltage monitoring reset, IWDT reset, or software reset is generated.

Figure 11.1 Mode Transitions



Figure 11.2 Operating Modes

- The sub-clock oscillator does not stop when entering software standby mode.
- It is possible to return from sleep mode to the previous operating state used before entering sleep mode. However, when a transition from low-speed operating mode to sleep mode is made, it is possible to enter the previous state used before entering low-speed operating mode.
- After exiting the reset state, operation starts in high-speed operating mode.

Table 11.3 Oscillator Usability in Each Mode

|                             | носо       | LOCO       | ILOCO  | Main Clock<br>Oscillator | Sub-Clock<br>Oscillator |
|-----------------------------|------------|------------|--------|--------------------------|-------------------------|
| High-speed operating mode   | Usable     | Usable     | Usable | Usable                   | Usable                  |
| Middle-speed operating mode | Usable     | Usable     | Usable | Usable                   | Usable                  |
| Low-speed operating mode    | Not usable | Not usable | Usable | Not usable               | Usable                  |

## 11.2 Register Descriptions

## 11.2.1 Standby Control Register (SBYCR)

Address(es): 0008 000Ch



| Bit       | Symbol | Bit Name         | Description                                                                                                                                                     | R/W |
|-----------|--------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b14 to b0 | _      | Reserved         | These bits are read as 0. The write value should be 0.                                                                                                          | R/W |
| b15       | SSBY   | Software Standby | Set entry to sleep mode or deep sleep mode after the WAIT instruction is executed     Set entry to software standby mode after the WAIT instruction is executed | R/W |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

### SSBY Bit (Software Standby)

The SSBY bit specifies the transition destination after the WAIT instruction is executed.

When the SSBY bit is set to 1, the MCU enters software standby mode after execution of the WAIT instruction. When the MCU returns to normal mode after an interrupt has triggered and exits from software standby mode, the SSBY bit remains 1. The SSBY bit can be cleared by writing 0 to the SSBY bit.

When the oscillation stop detection function enable bit (OSTDCR.OSTDE) in the oscillation stop detection control register is 1, the set value of the SSBY bit is invalid. Even if the SSBY bit is 1, the MCU will enter sleep mode or deep sleep mode after execution of the WAIT instruction.

# 11.2.2 Module Stop Control Register A (MSTPCRA)

Address(es): 0008 0010h



| Bit        | Symbol  | Bit Name                                        | Description                                                                                             | R/W |
|------------|---------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------|-----|
| b8 to b0   | _       | Reserved                                        | These bits are read as 1. The write value should be 1.                                                  | R/W |
| b9         | MSTPA9  | Multifunction Timer Pulse<br>Unit 2 Module Stop | Target module: MTU (MTU0 to MTU5) 0: This module clock is enabled 1: This module clock is disabled      | R/W |
| b14 to b10 | _       | Reserved                                        | These bits are read as 1. The write value should be 1.                                                  | R/W |
| b15        | MSTPA15 | Compare Match Timer<br>(Unit 0) Module Stop     | Target module: CMT unit 0 (CMT0, CMT1) 0: This module clock is enabled 1: This module clock is disabled | R/W |
| b16        | _       | Reserved                                        | This bit is read as 1. The write value should be 1.                                                     | R/W |
| b17        | MSTPA17 | 12-Bit A/D Converter<br>Module Stop             | Target module: S12AD 0: This module clock is enabled 1: This module clock is disabled                   | R/W |
| b27 to b18 | _       | Reserved                                        | These bits are read as 1. The write value should be 1.                                                  | R/W |
| b28        | MSTPA28 | Data Transfer Controller<br>Module Stop         | Target module: DTC 0: This module clock is enabled 1: This module clock is disabled                     | R/W |
| b31 to b29 | _       | Reserved                                        | These bits are read as 1. The write value should be 1.                                                  | R/W |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

# 11.2.3 Module Stop Control Register B (MSTPCRB)

Address(es): 0008 0014h



| Bit        | Symbol  | Bit Name                                              | Description                                                                                  | R/W |
|------------|---------|-------------------------------------------------------|----------------------------------------------------------------------------------------------|-----|
| b3 to b0   | _       | Reserved                                              | These bits are read as 1. The write value should be 1.                                       | R/W |
| b4         | MSTPB4  | Serial Communication<br>Interface SCIf Module<br>Stop | Target module: SCIf (SCI12) 0: This module clock is enabled 1: This module clock is disabled | R/W |
| b5         | _       | Reserved                                              | This bit is read as 1. The write value should be 1.                                          | R/W |
| b6         | MSTPB6  | DOC Module Stop                                       | Target module: DOC 0: This module clock is enabled 1: This module clock is disabled          | R/W |
| b16 to b7  | _       | Reserved                                              | These bits are read as 1. The write value should be 1.                                       | R/W |
| b17        | MSTPB17 | Serial Peripheral<br>Interface 0 Module Stop          | Target module: RSPI0 0: This module clock is enabled 1: This module clock is disabled        | R/W |
| b20 to b18 | _       | Reserved                                              | This bit is read as 1. The write value should be 1.                                          | R/W |
| b21        | MSTPB21 | I <sup>2</sup> C Bus Interface 0<br>Module Stop       | Target module: RIIC0 0: This module clock is enabled 1: This module clock is disabled        | R/W |
| b22        | _       | Reserved                                              | This bit is read as 1. The write value should be 1.                                          | R/W |
| b23        | MSTPB23 | CRC Calculator Module<br>Stop                         | Target module: CRC 0: This module clock is enabled 1: This module clock is disabled          | R/W |
| b25, b24   | _       | Reserved                                              | These bits are read as 1. The write value should be 1.                                       | R/W |
| b26        | MSTPB26 | Serial Communication<br>Interface 5 Module Stop       | Target module: SCI5 0: This module clock is enabled 1: This module clock is disabled         | R/W |
| b29 to b27 | _       | Reserved                                              | These bits are read as 1. The write value should be 1.                                       | R/W |
| b30        | MSTPB30 | Serial Communication<br>Interface 1 Module Stop       | Target module: SCI1 0: This module clock is enabled 1: This module clock is disabled         | R/W |
| b31        | _       | Reserved                                              | This bit is read as 1. The write value should be 1.                                          | R/W |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

Note 1. This bit should be rewritten while the oscillation of the clock to be controlled by this bit is stable.

## 11.2.4 Module Stop Control Register C (MSTPCRC)

Address(es): 0008 0018h



| Bit        | Symbol  | Bit Name               | Description                                            | R/W |
|------------|---------|------------------------|--------------------------------------------------------|-----|
| b0         | MSTPC0  | RAM0 Module Stop*1     | Target module: RAM0 (0000 0000h to 0000 FFFFh)         | R/W |
|            |         |                        | 0: RAM0 operating                                      |     |
|            |         |                        | 1: RAM0 stopped                                        |     |
| b18 to b1  | _       | Reserved               | These bits are read as 1. The write value should be 1. | R/W |
| b19        | MSTPC19 | Clock Frequency        | Target module: CAC                                     | R/W |
|            |         | Accuracy Measurement   | 0: This module clock is enabled                        |     |
|            |         | Circuit Module Stop*2  | 1: This module clock is disabled                       |     |
| b30 to b20 | _       | Reserved               | These bits are read as 1. The write value should be 1. | R/W |
| b31        | DSLPE   | Deep Sleep Mode Enable | 0: Deep sleep mode is disabled                         | R/W |
|            |         |                        | 1: Deep sleep mode is enabled                          |     |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

Note 1. The MSTPC0 bit should not be set to 1 during access to the corresponding RAM. The corresponding RAM should not be accessed while the MSTPC0 bit is set to 1.

Note 2. The MSTPC19 bit should be rewritten while the oscillation of the clock to be controlled by this bit is stable. For entering software standby mode after rewriting this bit, wait for two cycles of the slowest clock among the clocks output by the oscillators actually oscillating and execute the WAIT instruction.

### **DSLPE Bit (Deep Sleep Mode Enable)**

The DSLPE bit enables or disables a transition to deep sleep mode.

When the CPU executes the WAIT instruction with the DSLPE bit set to 1 and the SBYCR.SSBY and MSTPCRA.MSTPA28 bits meet specified conditions, the MCU enters deep sleep mode. For details, refer to section 11.6.2, Deep Sleep Mode.

## 11.2.5 Operating Power Control Register (OPCCR)

Address(es): 0008 00A0h



| Bit      | Symbol    | Bit Name                                               | Description                                                                                                                  | R/W |
|----------|-----------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|-----|
| b2 to b0 | OPCM[2:0] | Operating Power Control<br>Mode Select                 | b2 b0<br>0 0 0: High-speed operating mode<br>0 1 0: Middle-speed operating mode<br>Settings other than above are prohibited. | R/W |
| b3       | _         | Reserved                                               | This bit is read as 0. The write value should be 0.                                                                          | R/W |
| b4       | OPCMTSF   | Operating Power Control<br>Mode Transition Status Flag | Transition completed     During transition                                                                                   | R   |
| b7 to b5 | _         | Reserved                                               | These bits are read as 0. The write value should be 0.                                                                       | R/W |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

The OPCCR register is used to reduce power consumption in normal operating mode, sleep mode, and deep sleep mode. Power consumption can be reduced according to the operating frequency and operating voltage to be used by the OPCCR setting.

The OPCCR register cannot be rewritten under the following conditions:

- When the OPCCR.OPCMTSF flag is 1 (during transition)
- Time period from WAIT instruction execution for a sleep mode transition, until exit from sleep mode to normal operation
- Time period from WAIT instruction execution for a deep sleep mode transition, until exit from deep sleep mode to normal operation
- When the SOPCCR.SOPCM bit is 1 (low-speed operating mode)

The OPCCR register cannot be rewritten while the flash memory is being programmed or erased (P/E).

For the procedures of changing operating power control modes, refer to Function in section 11.5, Function for Lower Operating Power Consumption.

During sleep mode or mode transitions, do not write to the registers related to system control (indicated by 'SYSTEM' in the Module Symbol column in Table 5.1, List of I/O Registers (Address Order)).

#### OPCM[2:0] Bits (Operating Power Control Mode Select)

The OPCM[2:0] bits select operating power control mode in normal operating mode, sleep mode, and deep sleep mode. Table 11.4 shows the relationship between operating power control modes, the OPCM[2:0] and SOPCM bit settings, and the operating frequency and voltage ranges.

## **OPCMTSF Flag (Operating Power Control Mode Transition Status Flag)**

This flag indicates the switching control state during and after operating power mode transition.

This flag becomes 1 when the value of the OPCM[2:0] bits is rewritten, and 0 when mode transition is completed. Read this flag and confirm that it is 0 before proceeding to the next processing. Only rewrite the OPCM[2:0] bits when this flag is 0.



## 11.2.6 Sub Operating Power Control Register (SOPCCR)

Address(es): 0008 00AAh



| Bit      | Symbol   | Bit Name                                                   | Description                                                                             | R/W |
|----------|----------|------------------------------------------------------------|-----------------------------------------------------------------------------------------|-----|
| b0       | SOPCM    | Sub Operating Power Control<br>Mode Select                 | High-speed operating mode or middle-speed operating mode*1     Low-speed operating mode | R/W |
| b3 to b1 | _        | Reserved                                                   | These bits are read as 0. The write value should be 0.                                  | R/W |
| b4       | SOPCMTSF | Sub Operating Power Control<br>Mode Transition Status Flag | Transition completed     During transition                                              | R   |
| b7 to b5 | _        | Reserved                                                   | These bits are read as 0. The write value should be 0.                                  | R/W |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

Note 1. Depends on the setting of OPCCR.OPCM[2:0].

The SOPCCR register is used to reduce power consumption in normal operating mode, sleep mode, and deep sleep mode by controlling a transition to low-speed operating mode.

Setting this register initiates entry to/exit from low-speed operating mode.

Low-speed operating mode is used for the sub-clock oscillator only.

The OPCCR register cannot be rewritten when the SOPCM bit is 1 (low-speed operating mode).

The SOPCCR register cannot be rewritten under the following conditions:

- When the SOPCCR.SOPCMTSF flag is 1 (during transition)
- Time period from WAIT instruction execution for a sleep mode transition, until exit from sleep mode to normal operation
- Time period from WAIT instruction execution for a deep sleep mode transition, until exit from deep sleep mode to normal operation

This register cannot be rewritten while the flash memory is being programmed or erased (P/E).

For the procedures for changing operating power control modes, refer to Function in section 11.5, Function for Lower Operating Power Consumption.

During sleep mode or mode transitions, do not write to the registers related to system control (indicated by 'SYSTEM' in the Module Symbol column in Table 5.1, List of I/O Registers (Address Order)).

### **SOPCM Bit (Sub Operating Power Control Mode Select)**

The SOPCM bit selects operating power control in normal operating mode and sleep mode.

Setting this bit to 1 allows a transition to low-speed operating mode. Setting this bit to 0 allows a return to the operating mode (operating mode set by OPCCR.OPCM[2:0]) before the transition to low-speed operating mode.

Table 11.4 shows the relationship between operating power control modes, the OPCM[2:0] and SOPCM bit settings, and the operating frequency and voltage ranges.



### **SOPCMTSF Flag (Sub Operating Power Control Mode Transition Status Flag)**

The SOPCMTSF flag indicates the switching control state when the sub operating power control mode is switched. This flag becomes 1 when the value of the SOPCM bit is rewritten, and 0 when mode transition is completed. Read this flag and confirm that it is 0 before proceeding to the next processing. Only rewrite the SOPCM bit when this flag is 0.

Table 11.4 Operating Frequency and Voltage Ranges in Operating Power Control Modes

|                    |               |       |                      | Operating Frequency Range |                  |                  |                  |                                                   |  |
|--------------------|---------------|-------|----------------------|---------------------------|------------------|------------------|------------------|---------------------------------------------------|--|
| Operating<br>Power | OPCM<br>[2:0] | SOPCM | Operating<br>Voltage | Flash Memory Re           | ad Frequency     |                  |                  | Flash Memory<br>Programming/<br>Erasure Frequency |  |
| Control<br>Mode    | Bits          | Bit   | Range                | ICLK                      | FCLK             | PCLKD            | PCLKB            | FCLK                                              |  |
| High-speed         | 000b          | 00b 0 | 2.7 to 3.6 V         | Up to 32 MHz              | Up to 32 MHz     | Up to 32 MHz     | Up to 32 MHz     | 1 to 32 MHz                                       |  |
| operating<br>mode  |               |       | 2.4 to 2.7 V         | Up to 16 MHz              | Up to 16 MHz     | Up to 16 MHz     | Up to 16 MHz     | _                                                 |  |
|                    |               |       | 1.8 to 2.4 V         | Up to 8 MHz               | Up to 8 MHz      | Up to 8 MHz      | Up to 8 MHz      | _                                                 |  |
| Middle-speed       | 010b          | 0     | 2.4 to 3.6 V         | Up to 12 MHz              | Up to 12 MHz     | Up to 12 MHz     | Up to 12 MHz     | 1 to 12 MHz                                       |  |
| operating<br>mode  |               |       | 1.8 to 2.4 V         | Up to 8 MHz               | Up to 8 MHz      | Up to 8 MHz      | Up to 8 MHz      | 1 to 8 MHz                                        |  |
| Low-speed          | 000b          | 1     | 1.8 to 3.6 V         | Up to 32.768 kHz          | Up to 32.768 kHz | Up to 32.768 kHz | Up to 32.768 kHz | _                                                 |  |
| operating<br>mode  | 010b          | 1     | 1.8 to 3.6 V         | ]                         |                  |                  |                  |                                                   |  |

Note: When using the FCLK at lower than 4 MHz during programming or erasing the flash memory, the frequency can be set to 1, 2, or 3 MHz.

Each operating power control mode is described below.

#### • High-Speed Operating Mode

The maximum operating frequency during FLASH read is 32 MHz for ICLK, FCLK, PCLKD, and PCLKB. The operating voltage range is 1.8 to 3.6 V during FLASH read. However, for ICLK, FCLK, PCLKD, and PCLKB, the maximum operating frequency during FLASH read is 16 MHz when the operating voltage is 2.4 V or larger and smaller than 2.7 V. The maximum operating frequency during FLASH read is 8 MHz for all the clocks when the operating voltage is 1.8 V or larger and smaller than 2.4 V.

During FLASH programming/erasure, the operating frequency range is 1 to 32 MHz and the operating voltage range is 2.7 to 3.6 V.

After a reset is canceled, operation is started from this mode.

Figure 11.3 shows the operating voltages and frequencies in high-speed operating mode.



Figure 11.3 Operating Voltages and Frequencies in High-Speed Operating Mode

Note: When using the FCLK at lower than 4 MHz during programming or erasing the flash memory, the frequency can be set to 1, 2, or 3 MHz.

### • Middle-Speed Operating Mode

As compared to high-speed operating mode, this mode reduces power consumption for low-speed operation. The maximum operating frequency during FLASH read is 12 MHz for ICLK, FCLK, PCLKD, and PCLKB. The operating voltage range is 1.8 to 3.6 V during FLASH read. The maximum operating frequency during FLASH read is 8 MHz for all the clocks when the operating voltage is 1.8 V or larger and smaller than 2.4 V.

During FLASH programming/erasure, the operating frequency range is 1 to 12 MHz and the operating voltage range is 1.8 to 3.6 V. The maximum operating frequency during FLASH programming/erasure is 8 MHz when the operating voltage is 1.8 V or larger and smaller than 2.4 V.

The power consumption of this mode is lower than that of high speed mode under the same conditions.

Figure 11.4 shows the operating voltages and frequencies in middle-speed operating mode.



Figure 11.4 Operating Voltages and Frequencies in Middle-Speed Operating Mode

Note: When using the FCLK at lower than 4 MHz during programming or erasing the flash memory, the frequency can be set to 1, 2, or 3 MHz.

#### • Low-Speed Operating Mode

A transition to low-speed operating mode is set by writing 1 to the SOPCM bit in the SOPCCR register. The setting of the OPCM[2:0] bits cannot be modified during low-speed operating mode. This mode is used only for the sub oscillator of 32.768 kHz.

During reading the flash memory (FLASH), the maximum operating frequency of ICLK, FCLK, PCLKD, and PCLKB is 32.768 kHz. The operating voltage is in the range of 1.8 to 3.6 V.

The following restrictions apply when low-speed operating mode is selected:

- P/E operations for flash memory are prohibited.
- The main clock oscillator, LOCO, and HOCO cannot be used.

Note: The SOPCM bit cannot be set to 1 when the HOCOCR.HCSTP bit is 0 (HOCO is operating). The SOPCM bit cannot be set to 1 when the MOSCCR.MOSTP bit is 0 (MOSC is operating). The SOPCM should not be set to 1 when the LOCOCR.LCSTP bit is 0 (LOCO is operating).

Figure 11.5 shows the operating voltages and frequencies in low-speed operating mode.



Figure 11.5 Operating Voltages and Frequencies in Low-Speed Operating Mode

## 11.2.7 Sleep Mode Return Clock Source Switching Register (RSTCKCR)

Address(es): 0008 00A1h



| Bit      | Symbol            | Bit Name                                           | Description                                                                                                                                                          | R/W |
|----------|-------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b2 to b0 | RSTCKSEL<br>[2:0] | Sleep Mode Return Clock<br>Source Select           | b2 b0 0 0 0: LOCO is selected 0 0 1: HOCO is selected*1 0 1 0: Main clock oscillator is selected Settings other than above are prohibited when the RSTCKEN bit is 1. | R/W |
| b6 to b3 | _                 | Reserved                                           | These bits are read as 0. The write value should be 0.                                                                                                               | R/W |
| b7       | RSTCKEN           | Sleep Mode Return Clock<br>Source Switching Enable | Clock source switching at exit from sleep mode is disabled     Clock source switching at exit from sleep mode is enabled                                             | R/W |

Note: Set the PRCR.PRC1 bit to 1 (write enabled) before rewriting this register.

Note 1. HOCO can only be selected when entering high-speed operating mode.

RSTCKCR is used to control clock source switching at exit from sleep mode.

When exit from sleep mode is initiated by setting RSTCKCR, the main clock oscillator stop bit in the main clock oscillator control register (MOSCCR.MOSTP), the HOCO stop bit in the high-speed on-chip oscillator control register (HOCOCR.HCSTP), and the LOCO stop bit in the low-speed on-chip oscillator control register (LOCOCR.LCSTP) are automatically modified to the operating state corresponding to the clock source to be used after transition. The value of the RSTCKSEL[2:0] bits is automatically reloaded to the clock source select bits in system clock control register 3 (SCKCR3.CKSEL[2:0]).

### RSTCKSEL[2:0] Bits (Sleep Mode Return Clock Source Select)

The RSTCKSEL[2:0] bits select the clock source to be used at exit from sleep mode.

The clock source selected by the RSTCKSEL[2:0] bits is enabled only when the RSTCKEN bit is 1.

As shown in Figure 11.2, Operating Modes, when returning from sleep mode to high-speed operating mode, the LOCO, HOCO, or main clock oscillator can be selected. When returning from sleep mode to middle-speed operating mode, the LOCO or main clock oscillator can be selected. However, in this case, the frequency of each clock (ICLK, FCLK, PCLKD, and PCLKB) must be lower than 12 MHz when the power supply voltage is 2.4 V or above, and lower than 8 MHz when the voltage is below 2.4 V.

Table 11.5 When Exiting Sleep Mode to High-Speed Operating Mode and Middle-Speed Operating Mode

| Operating Mode during Sleep                                                   | Clock Source<br>during Sleep | RSTCKSEL                     | Operating Mode after Exiting | Clock Source after<br>Exiting |
|-------------------------------------------------------------------------------|------------------------------|------------------------------|------------------------------|-------------------------------|
| High-speed operating mode or                                                  | Sub-clock oscillator         | 000b (LOCO)                  | High-speed                   | LOCO                          |
| low-speed operating mode after exit from high-speed                           |                              | 001b (HOCO)                  | operating mode               | HOCO                          |
| operating mode                                                                |                              | 010b (main clock oscillator) | _                            | Main clock oscillator         |
| Middle-speed operating mode                                                   | Sub-clock oscillator         | 000b (LOCO)                  | Middle-speed operating mode  | LOCO                          |
| or low-speed operating mode<br>after exit from middle-speed<br>operating mode |                              | 010b (main clock oscillator) |                              | Main clock oscillator*1       |

Note 1. The frequency of each clock (ICLK, FCLKD, and PCLKB) must be lower than 12 MHz when the power supply voltage is 2.4 V or above, and lower than 8 MHz when the voltage is below 2.4 V.

### **RSTCKEN Bit (Sleep Mode Return Clock Source Switching Enable)**

The RSTCKEN bit enables or disables clock source switching when sleep mode is exited.

When returning from sleep mode while this bit is enabled, the SOPCM bit in the SOPCCR register is automatically rewritten to 0 (middle-speed operating mode or high-speed operating mode).

The value of the frequency division setting (in the SCKCR register) is retained.

To exit sleep mode to middle-speed operating mode when the main clock oscillator is selected, the frequency of each clock must be lower than 12 MHz when the power supply voltage is 2.4 V or above, and lower than 8 MHz when the voltage is below 2.4 V.



## 11.3 Reducing Power Consumption by Switching Clock Signals

The clock frequency can change by setting the SCKCR.FCK[3:0], ICK[3:0], PCKB[3:0], and PCKD[3:0] bits. The CPU, DTC, ROM, and RAM clocks can be set by the ICK[3:0] bits. The peripheral module clocks can be set by the PCKB[3:0] and PCKD[3:0] bits.

The flash memory clock can be set by the FCK[3:0] bits.

For details, refer to section 9, Clock Generation Circuit.

## 11.4 Module Stop Function

The module stop function can be set for each on-chip peripheral module.

When the MSTPmi bit (m = A to C; i = 0 to 31) in MSTPCRA to MSTPCRC is set to 1, the specified module stops operating and enters the module stop state, but the CPU continues to operate independently. When the corresponding MSTPmi bit is set to 0, the module exits the module state and restarts operating at the end of the bus cycle. The internal states of modules are retained in the module stop state.

After a reset is canceled, all modules other than the DTC, and on-chip RAM are in the module stop state. Basically the registers in the module stop state cannot be read or written. However, note that data may be written to these registers if write access is made immediately after the setting of the module stop state. To avoid this, always write to the module stop registers after confirming that the last register setting is done.

### 11.5 Function for Lower Operating Power Consumption

By selecting an appropriate operating power control mode according to the operating frequency and operating voltage, power consumption can be reduced in normal mode, sleep mode, and deep sleep mode.

### 11.5.1 Setting Operating Power Control Mode

Examples of the procedures for switching operating power control modes are shown below:

- (1) Switching from Normal Power Consumption Mode to Low Power Consumption Mode
- Example 1: From high-speed operating mode to middle-speed operating mode

(High-speed operation in high-speed operating mode)

Set the frequency of each clock to lower than the maximum operating frequency for middle-speed operating mode

Confirm that the OPCCR.OPCMTSF flag is 0 (transition completed)

Set the OPCCR.OPCM[2:0] bits to 010b (middle-speed operating mode)

Confirm that the OPCCR.OPCMTSF flag is 0 (transition completed)

(Middle-speed operation in middle-speed operating mode)

• Example 2: From high-speed/middle-speed operating mode to low-speed operating mode

(High-speed operation in high-speed operating mode/middle-speed operation in middle-speed operating mode)

 $\downarrow$ 

Set the frequency of each clock to lower than the maximum operating frequency for low-speed operating mode

 $\downarrow$ 

Confirm that all clock sources but the sub-clock oscillator are stopped

1

Confirm that the SOPCCR.SOPCMTSF flag is 0 (transition completed)

,

Set the SOPCCR.SOPCM bit to 1 (low-speed operating mode)

 $\downarrow$ 

Confirm that the SOPCCR.SOPCMTSF flag is 0 (transition completed)

1

Low-speed operation in low-speed operating mode

- (2) Switching from Low Power Consumption Mode to Normal Power Consumption Mode
- Example 1: From low-speed operating mode to high-speed/middle-speed operating mode

Low-speed operation in low-speed operating mode

1

Confirm that the SOPCCR.SOPCMTSF flag is 0 (transition completed)

1

Set the SOPCCR.SOPCM bit to 0 (high-speed operating mode or middle-speed operating mode)

 $\downarrow$ 

Confirm that the SOPCCR.SOPCMTSF flag is 0 (transition completed)

 $\downarrow$ 

Set the frequency of each clock to lower than the maximum operating frequency for high-speed/middle-speed operating mode

,

(High-speed operation in high-speed operating mode/middle-speed operation in middle-speed operating mode)

• Example 2: From middle-speed operating mode to high-speed operating mode

Middle-speed operation in middle-speed operating mode

,

Confirm that the OPCCR.OPCMTSF flag is 0 (transition completed)

 $\downarrow$ 

Set the OPCCR.OPCM[2:0] bit to 0 (high-speed operating mode)

,

Confirm that the OPCCR.OPCMTSF flag is 0 (transition completed)

**1** 

Set the frequency of each clock to lower than the maximum operating frequency for high-speed operating mode

1

High-speed operation in high-speed operating mode

### 11.6 Low Power Consumption Modes

### 11.6.1 Sleep Mode

## 11.6.1.1 Entry to Sleep Mode

When the WAIT instruction is executed while the SBYCR.SSBY bit is 0, the CPU enters sleep mode. In sleep mode, the CPU stops operating but the contents of its internal registers are retained. Other peripheral functions do not stop. Counting by the IWDT stops if a transition to sleep mode is made while the IWDT is being used in auto-start mode and the OFS0.IWDTSLCSTP bit is 1. In the same way, counting by the IWDT stops if a transition to sleep mode is made while the IWDT is being used in register start mode and the IWDTCSTPR.SLCSTP bit is 1.

Furthermore, counting by the IWDT continues if a transition to sleep mode is made while the IWDT is being used in auto-start mode and the OFS0.IWDTSLCSTP bit is 0 (counting by the IWDT continues through transitions to low power consumption modes). In the same way, counting by the IWDT continues if a transition to sleep mode is made while the IWDT is being used in register start mode and the IWDTCSTPR.SLCSTP bit is 0.

To use sleep mode, make the following settings and then execute a WAIT instruction.

- (1) Set the PSW.I bit\*1 of the CPU to 0.
- (2) Set the interrupt request destination\*2 to be used for exit from sleep mode.
- (3) Set the priority\*3 of the interrupt to be used for exit from sleep mode to a level higher than the setting of the PSW.IPL[3:0] bits\*1 of the CPU.
- (4) Set the IERm.IENj bit\*3 to 1 for the interrupt.
- (5) Read the I/O register that is written last and confirm that the written value has been reflected.
- (6) Execute the WAIT instruction (this automatically sets the I bit\*1 in the PSW of the CPU to 1).
- Note 1. For details, refer to section 2, CPU.
- Note 2. For details, refer to section 14.4.3, Selecting Interrupt Request Destinations.
- Note 3. For details, refer to section 14, Interrupt Controller (ICUb).

### 11.6.1.2 Exit from Sleep Mode

Exit from sleep mode is initiated by any interrupt, a RES# pin reset, a power-on reset, a voltage monitoring reset, or a reset caused by an IWDT underflow.

- Initiated by an interrupt
  - An interrupt initiates exit from sleep mode and the interrupt exception handling starts. If a maskable interrupt has been masked by the CPU (the priority level\*1 of the interrupt has been set to a value lower than that of the PSW.IPL[3:0] bits\*2 of the CPU), sleep mode is not exited.
- Initiated by a RES# pin reset
  - When the RES# pin is driven low, the MCU enters the reset state. When the RES# pin is driven high after the reset signal is input for a predetermined time period, the CPU starts the reset exception handling.
- Initiated by a power-on reset
  - A power-on reset asserts a reset to the MCU.
  - When a power-on reset is negated by a rise in the supply voltage, the CPU starts the reset exception handling.
- Initiated by a voltage monitoring reset
  - A voltage monitoring reset asserts a reset to the MCU.
  - When a voltage monitoring reset is negated by a rise in the supply voltage, the CPU starts the reset exception handling.
- Initiated by an independent watchdog timer reset
  - An internal reset generated by an IWDT underflow asserts a reset to the MCU. However, when IWDT counting is stopped in sleep mode by setting OFS0.IWDTSTRT = 0 and OFS0.IWDTSLCSTP = 1, or OFS0.IWDTSTRT = 1 and IWDTCSTPR.SLCSTP = 1, the IWDT is stopped in sleep mode and sleep mode is not exited by the independent watchdog timer reset.
- Note 1. For details, refer to section 14, Interrupt Controller (ICUb).
- Note 2. For details, refer to section 2, CPU.

### 11.6.1.3 Sleep Mode Return Clock Source Switching Function

To switch the clock source used for exit from sleep mode, set the sleep mode return clock source switching register (RSTCKCR) and the wait control register for each clock. When the return interrupt is generated, after oscillation settling of the oscillator specified as the return clock, the clock source is automatically switched, and then operation exits sleep mode. At this time, the registers related to clock source switching are automatically rewritten.

For details, refer to section 11.2.7, Sleep Mode Return Clock Source Switching Register (RSTCKCR). For details on settings the oscillation stabilization wait time, refer to section 9.2.11, Main Clock Oscillator Wait Control Register (MOSCWTCR) and section 9.2.12, High-Speed On-Chip Oscillator Wait Control Register (HOCOWTCR).

### 11.6.2 Deep Sleep Mode

### 11.6.2.1 Entry to Deep Sleep Mode

When a WAIT instruction is executed with the MSTPCRC.DSLPE bit set to 1, the MSTPCRA.MSTPA28 bit set to 1, and the SBYCR.SSBY bit cleared to 0, a transition to deep sleep mode is made.

In deep sleep mode, the CPU and the DTC, ROM, and RAM clocks stop. Peripheral functions do not stop.

Counting by the IWDT stops if a transition to deep sleep mode is made while the IWDT is being used in auto-start mode and the OFS0.IWDTSLCSTP bit is 1. In the same way, counting by the IWDT stops if a transition to deep sleep mode is made while the IWDT is being used in register start mode and the IWDTCSTPR.SLCSTP bit is 1.

Furthermore, counting by the IWDT continues if a transition to deep sleep mode is made while the IWDT is being used in auto-start mode and the OFS0.IWDTSLCSTP bit is 0 (counting by the IWDT continues through transitions to low power consumption modes). In the same way, counting by the IWDT continues if a transition to deep sleep mode is made while the IWDT is being used in register start mode and the IWDTCSTPR.SLCSTP bit is 0.

To use deep sleep mode, make the following settings and then execute a WAIT instruction.

- (1) Set the PSW.I bit\*1 of the CPU to 0.
- (2) Set the interrupt request destination\*2 to be used for exit from deep sleep mode.
- (3) Set the priority\*3 of the interrupt to be used for exit from deep sleep mode to a level higher than the setting of the PSW.IPL[3:0] bits\*1 of the CPU.
- (4) Set the IERm.IENj bit\*3 to 1 for the interrupt.
- (5) Read the I/O register that is written last and confirm that the written value has been reflected.
- (6) Execute a WAIT instruction (executing a WAIT instruction causes automatic setting of the PSW.I bit\*1 of the CPU to 1).
- Note 1. For details, refer to section 2, CPU.
- Note 2. For details, refer to section 14.4.3, Selecting Interrupt Request Destinations.
- Note 3. For details, refer to section 14, Interrupt Controller (ICUb).

### 11.6.2.2 Exit from Deep Sleep Mode

Exit from deep sleep mode is initiated by any interrupt, a RES# pin reset, a power-on reset, a voltage monitoring reset, or a reset caused by an IWDT underflow.

### • Initiated by an interrupt

An interrupt initiates exit from deep sleep mode and the interrupt exception handling starts. If a maskable interrupt has been masked by the CPU (the priority level\*1 of the interrupt has been set to a value lower than that of the PSW.IPL[3:0] bits\*2 of the CPU), deep sleep mode is not exited.

• Initiated by the RES# pin reset

When the RES# pin is driven low, the MCU enters the reset state. When the RES# pin is driven high after the reset signal is input for a predetermined time period, the CPU starts the reset exception handling.

• Initiated by a power-on reset

A power-on reset asserts a reset to the MCU.

When a power-on reset is negated by a rise in the supply voltage, the CPU starts the reset exception handling.

• Initiated by a voltage monitoring reset

A voltage monitoring reset asserts a reset to the MCU.

When a voltage monitoring reset is negated by a rise in the supply voltage, the CPU starts the reset exception handling.

• Initiated by the independent watchdog timer

An internal reset generated by an IWDT underflow asserts a reset to the MCU. However, when IWDT counting is stopped in deep sleep mode by setting OFS0.IWDTSTRT = 0 and OFS0.IWDTSLCSTP = 1, or OFS0.IWDTSTRT = 1 and IWDTCSTPR.SLCSTP = 1, the IWDT is stopped in deep sleep mode and deep sleep mode is not exited by the independent watchdog timer reset.

Note 1. For details, refer to section 14, Interrupt Controller (ICUb).

Note 2. For details, refer to section 2, CPU.

### 11.6.3 Software Standby Mode

## 11.6.3.1 Entry to Software Standby Mode

When a WAIT instruction is executed with the SBYCR.SSBY bit set to 1, a transition to software standby mode is made. In this mode, the CPU, on-chip peripheral functions, and all the other functions except the sub-clock oscillator stop. However, the contents of the CPU internal registers, RAM data, the states of on-chip peripheral functions, the I/O ports, and the sub-clock oscillator are retained. Software standby mode allows significant reduction in power consumption because the oscillator stops in this mode.

Set the DTCST.DTCST bit to 0 before executing the WAIT instruction.

Counting by the IWDT stops if a transition to software standby mode is made while the IWDT is being used in auto-start mode and the OFS0.IWDTSLCSTP bit is 1. In the same way, counting by the IWDT stops if a transition to software standby mode is made while the IWDT is being used in register start mode and the IWDTCSTPR.SLCSTP bit is 1.

Furthermore, counting by the IWDT continues if a transition to software standby mode is made while the IWDT is being used in auto-start mode and the OFS0.IWDTSLCSTP bit is 0 (counting by the IWDT continues through transitions to low power consumption modes). In the same way, counting by the IWDT continues if a transition to software standby mode is made while the IWDT is being used in register start mode and the IWDTCSTPR.SLCSTP bit is 0. To use software standby mode, make the following settings and then execute a WAIT instruction.

- (1) Set the PSW.I bit\*1 of the CPU to 0.
- (2) Set the interrupt request destination\*2 to be used for recovery from software standby mode to the CPU.
- (3) Set the priority\*3 of the interrupt to be used for recovery from software standby mode to a level higher than the setting of the PSW.IPL[3:0] bits\*1 of the CPU.
- (4) Set the IERm.IENj bit\*3 to 1 for the interrupt.
- (5) Read the I/O register that is written last and confirm that the written value has been reflected.
- (6) Execute a WAIT instruction (executing a WAIT instruction causes automatic setting of the PSW.I bit\*1 of the CPU to 1).
- Note 1. For details, refer to section 2, CPU.
- Note 2. For details, refer to section 14.4.3, Selecting Interrupt Request Destinations.
- Note 3. For details, refer to section 14, Interrupt Controller (ICUb).

### 11.6.3.2 Exit from Software Standby Mode

Exit from software standby mode is initiated by an external pin interrupt (the NMI or IRQ0 to IRQ7), peripheral interrupts (the RTC alarm, RTC interval, IWDT, and voltage monitoring interrupts), a RES# pin reset, a power-on reset, a voltage monitoring reset, or an independent watchdog timer reset. When any trigger which initiates exit from software standby mode is asserted, the oscillators which were operating before entry to software standby mode restart operation. After the oscillation of all these oscillators has been stabilized, operation returns from software standby mode.

- Initiated by an interrupt
  - When an interrupt request from among the NMI, IRQ0 to IRQ7, RTC alarm, RTC interval, IWDT, and voltage monitoring interrupts is generated, each of the oscillators which was operating before the transition to software standby mode resumes oscillation. After the oscillation stabilization wait time of each oscillator set by the MOSCWTCR.MSTS[4:0] bits or HOCOWTCR.HSTS[4:0] bits has elapsed, the MCU exits software standby mode and interrupt exception processing starts.
- Initiated by a RES# pin reset

  Clock oscillation starts when the low level is applied to the RES# pin. Clock supply for the MCU starts at the same
  time. Keep the level on the RES# pin low over the time required for oscillation of the clocks to become stable. Reset
  exception processing starts when the high level is applied to the RES# pin.
- Initiated by a power-on reset
  - A power-on reset asserts a reset to the MCU.
  - When a power-on reset is negated by a rise in the supply voltage, the CPU starts the reset exception handling.
- Initiated by a voltage monitoring reset
  - A voltage monitoring reset asserts a reset to the MCU.
  - When a voltage monitoring reset is negated by a rise in the supply voltage, the CPU starts the reset exception handling.
- Initiated by an independent watchdog timer reset
  - An internal reset generated by an IWDT underflow asserts a reset to the MCU.
  - Note that the independent watchdog timer is stopped in software standby mode due to the register settings (OFS0.IWDTSTRT = 0 and OFS0.IWDTSLCSTP = 1, or OFS0.IWDTSTRT = 1 and IWDTCSTPR.SLCSTP = 1) in software standby mode. In that case, exit from software standby mode by the independent watchdog timer reset cannot be done.

## 11.6.3.3 Example of Software Standby Mode Application

Figure 11.6 shows an example of entry to software standby mode by the falling edge of the IRQn pin, and exit from software standby mode by the rising edge of the IRQn pin.

In this example, an IRQn interrupt is accepted with the IRQCRi.IRQMD[1:0] bits of the ICU set to 01b (falling edge), and then the IRQCRi.IRQMD[1:0] bits are set to 10b (rising edge). After that, the SBYCR.SSBY bit is set to 1 and the WAIT instruction is executed. Thus entry to software standby mode is completed. After that, exit from software standby mode is initiated by the rising edge of the IRQn pin.

To exit software standby mode, settings of the interrupt controller (ICU) are also necessary. For details, refer to section 14, Interrupt Controller (ICUb).



Figure 11.6 Example of Software Standby Mode Application

### 11.7 Usage Notes

### 11.7.1 I/O Port States

I/O port states are retained in software standby mode. Therefore, the supply current is not reduced if output signals are high level.

## 11.7.2 Module Stop State of DTC

Before setting the MSTPCRA.MSTPA28 bit to 1, set the DTCST.DTCST bit of the DTC to 0 to avoid activating the DTC module.

For details, refer to section 16, Data Transfer Controller (DTCa).

### 11.7.3 On-Chip Peripheral Module Interrupts

Interrupts do not operate in the module stop state. Therefore, if the module stop state is made after an interrupt request is generated, a CPU interrupt source or a DTC startup source cannot be cleared. For this reason, disable interrupts before entering the module stop state.

### 11.7.4 Write Access to MSTPCRA, MSTPCRB, and MSTPCRC

Write accesses to MSTPCRA, MSTPCRB, and MSTPCRC should be made only by the CPU.

## 11.7.5 Timing of WAIT Instructions

The WAIT instruction is executed before completion of the preceding register write. The WAIT instruction being executed before the register setting is modified may cause unintended operation. To avoid this, always execute the WAIT instruction after confirming that the last register setting is done.

### 11.7.6 Rewrite the Register by DTC in Sleep Mode

Depending on the settings of the OFS0.IWDTSLCSTP bit and IWDTCSTPR.SLCSTP bit, the IWDT may also stop in sleep mode. To avoid this, do not set up the DTC to rewrite any registers related to the IWDT in sleep mode. The RSTCKCR register is a register that switches the clock source at exit from sleep mode. Changing the RSTCKCR register in sleep mode causes unintended operation, so do not write to this register in sleep mode.



# 12. Register Write Protection Function

The register write protection function protects important registers from being overwritten for in case a program runs out of control. The registers to be protected are set with the protect register (PRCR).

Table 12.1 lists the association between the PRCR bits and the registers to be protected.

Table 12.1 Association between PRCR Bits and Registers to be Protected

| PRCR Bit | Register to be Protected                                                                                                                                                                                                                                        |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PRC0     | Registers related to the clock generation circuit:     SCKCR, SCKCR3, MOSCCR, SOSCCR, LOCOCR, ILOCOCR, HOCOCR, OSTDCR, OSTDSR, CKOCR                                                                                                                            |
| PRC1     | Register related to the operating modes: SYSCR1 Registers related to low power consumption functions: SBYCR, MSTPCRA, MSTPCRB, MSTPCRC, OPCCR, RSTCKCR, SOPCCR Registers related to the clock generation circuit: MOFCR, MOSCWTCR Software reset register: SWRR |
| PRC2     | Register related to the clock generation circuit:     HOCOWTCR                                                                                                                                                                                                  |
| PRC3     | Registers related to the LVD:     LVCMPCR, LVDLVLR, LVD1CR0, LVD1CR1, LVD1SR, LVD2CR0, LVD2CR1, LVD2SR                                                                                                                                                          |

## 12.1 Register Descriptions

## 12.1.1 Protect Register (PRCR)

Address(es): 0008 03FEh



| Bit       | Symbol     | Bit Name      | Function                                                                                                                                                                                                            | R/W   |
|-----------|------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| b0        | PRC0       | Protect Bit 0 | Enables writing to the registers related to the clock generation circuit.  0: Write disabled  1: Write enabled                                                                                                      | R/W   |
| b1        | PRC1       | Protect Bit 1 | Enables writing to the registers related to operating modes, low power consumption functions, and software reset.  0: Write disabled  1: Write enabled                                                              | R/W   |
| b2        | PRC2       | Protect Bit 2 | Enables writing to the registers related to the clock generation circuit.  0: Write disabled  1: Write enabled                                                                                                      | R/W   |
| b3        | PRC3       | Protect Bit 3 | Enables writing to the registers related to the LVD.  0: Write disabled  1: Write enabled                                                                                                                           | R/W   |
| b7 to b4  | _          | Reserved      | These bits are read as 0. The write value should be 0.                                                                                                                                                              | R/W   |
| b15 to b8 | PRKEY[7:0] | PRC Key Code  | These bits control permission and prohibition of writing to the PRCR register.  To modify the PRCR register, write A5h to the 8 higher-order bits and the desired value to the 8 lower-order bits as a 16-bit unit. | R/W*1 |

Note 1. Write data is not retained.

## PRCi Bits (Protect Bit i) (i = 0 to 3)

These bits enable or disable writing to the corresponding registers to be protected.

Setting the PRCi bits to 1 and 0 enable and disable writing to the corresponding registers to be protected, respectively.

# 13. Exception Handling

## 13.1 Exception Events

During execution of a program by the CPU, the occurrence of a certain event may cause execution of that program to be suspended and execution of another program to be started. Such kinds of events are called exception events.

The RX CPU supports six types of exceptions. The types of exception events are shown in Figure 13.1.

The occurrence of an exception causes the processor mode to switch to supervisor mode.



Figure 13.1 Types of Exception Events

### 13.1.1 Undefined Instruction Exception

An undefined instruction exception occurs when execution of an undefined instruction (an instruction not implemented) is detected.

## 13.1.2 Privileged Instruction Exception

A privileged instruction exception occurs when execution of a privileged instruction is detected in user mode. Privileged instructions can be executed only in supervisor mode.

#### 13.1.3 Reset

A reset is generated by input of a reset signal to the CPU. This has the highest priority of any exception and is always accepted.

## 13.1.4 Non-Maskable Interrupt

A non-maskable interrupt is generated by input of a non-maskable interrupt signal to the CPU and is only used when a fatal fault is considered to have occurred in the system. Never use the non-maskable interrupt with an attempt to return to the program that was being executed at the time of interrupt generation after the exception handling routine is ended.

## 13.1.5 Interrupts

Interrupts are generated by the input of interrupt signals to the CPU. A fast interrupt can be selected as the interrupt with the highest priority. In the case of the fast interrupt, hardware pre-processing and hardware post-processing are handled fast. The priority level of the fast interrupt is 15 (the highest). The exception handling of interrupts is masked when the I bit in PSW is 0.

### 13.1.6 Unconditional Trap

An unconditional trap is generated when the INT or BRK instruction is executed.

## 13.2 Exception Handling Procedure

In the exception handling, part of the processing is handled automatically by hardware and part of it is handled by a program (exception handling routine) that has been written by the user. Figure 13.2 shows the processing procedure when an exception other than a reset is accepted.



Figure 13.2 Outline of Exception Handling Procedure

When an exception is accepted, hardware processing by the RX CPU is followed by access to the vector to acquire the address of the branch destination. In the vector, a vector address is allocated to each exception, and the branch destination address of the exception handling routine is written to each vector address.

Hardware pre-processing by the RX CPU handles saving of the contents of the program counter (PC) and processor status word (PSW). In the case of a fast interrupt, the contents are saved in the backup PC (BPC) and the backup PSW (BPSW), respectively. In the case of exceptions other than a fast interrupt, the contents are saved in the stack area. General purpose registers and control registers other than the PC and PSW that are to be used within the exception handling routine must be saved on the stack by a user program at the start of the exception handling routine. On completion of processing by an exception handling routine, execution is restored from the exception handling routine to the original program by saving the registers saved on the stack and executing the RTE instruction. For return from a fast interrupt, the RTFI instruction is used instead. In the case of a non-maskable interrupt, however, finish the program or reset the system without returning to the original program.

Hardware post-processing by the RX CPU handles restoration of the contents of PC and PSW. In the case of a fast interrupt, the values of BPC and BPSW are restored to PC and PSW, respectively. In the case of exceptions other than a fast interrupt, the values are restored from the stack to PC and PSW.



## 13.3 Acceptance of Exception Events

When an exception occurs, the CPU suspends the execution of the program and processing branches to the exception handling routine.

## 13.3.1 Acceptance Timing and Saved PC Value

Table 13.1 lists the timing of acceptance and the program counter (PC) value to be saved for each exception event.

Table 13.1 Acceptance Timing and Saved PC Value

| Exception Event Undefined instruction exception Privileged instruction exception |                                                                                                          | Type of Handling                                      | Acceptance<br>Timing                                       | Value Saved in BPC or on the Stack PC value of the instruction that generated the exception PC value of the instruction that generated the exception |
|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                  |                                                                                                          | Instruction canceling type Instruction canceling type | During instruction execution  During instruction execution |                                                                                                                                                      |
|                                                                                  |                                                                                                          |                                                       |                                                            |                                                                                                                                                      |
| Non-maskable interrupt                                                           | During execution of the RMPA,<br>SCMPU, SMOVB, SMOVF,<br>SMOVU, SSTR, SUNTIL, and<br>SWHILE instructions | Instruction suspending type                           | During instruction execution                               | PC value of the instruction being executed                                                                                                           |
|                                                                                  | Other than above                                                                                         | Instruction completion type                           | At the next break between instructions                     | PC value of the next instruction                                                                                                                     |
| Interrupt                                                                        | During execution of the RMPA,<br>SCMPU, SMOVB, SMOVF,<br>SMOVU, SSTR, SUNTIL, and<br>SWHILE instructions | Instruction suspending type                           | During instruction execution                               | PC value of the instruction being executed                                                                                                           |
|                                                                                  | Other than above                                                                                         | Instruction completion type                           | At the next break between instructions                     | PC value of the next instruction                                                                                                                     |
| Unconditional trap                                                               |                                                                                                          | Instruction completion type                           | At the next break between instructions                     | PC value of the next instruction                                                                                                                     |

## 13.3.2 Vector and Site for Saving the Values in the PC and PSW

The vector for each type of exception and the site for saving the values of the program counter (PC) and processor status word (PSW) are listed in Table 13.2.

Table 13.2 Vector and Site for Saving the Values in the PC and PSW

| Exception                        |                  | Vector                          | Site for Saving the Values in the PC and PSW |  |
|----------------------------------|------------------|---------------------------------|----------------------------------------------|--|
| Undefined instruction exception  |                  | Fixed vector table              | Stack                                        |  |
| Privileged instruction exception |                  | Fixed vector table              | Stack                                        |  |
| Reset                            |                  | Fixed vector table              | Nowhere                                      |  |
| Non-maskable in                  | terrupt          | Fixed vector table              | Stack                                        |  |
| Interrupt                        | Fast interrupt   | FINTV                           | BPC and BPSW                                 |  |
|                                  | Other than above | Relocatable vector table (INTB) | Stack                                        |  |
| Unconditional trap               |                  | Relocatable vector table (INTB) | Stack                                        |  |

## 13.4 Hardware Processing for Accepting and Returning from Exceptions

This section describes the hardware processing for accepting and returning from exceptions other than a reset.

### (1) Hardware Pre-Processing for Accepting an Exception

### (a) Saving PSW

• For a fast interrupt

 $PSW \rightarrow BPSW$ 

• For exceptions other than a fast interrupt

PSW → Stack

### (b) Updating PM, U, and I Bits in PSW

I: Set to 0

U: Set to 0

PM: Set to 0

### (c) Saving PC

• For a fast interrupt

 $PC \rightarrow BPC$ 

• For exceptions other than a fast interrupt

 $PC \rightarrow Stack$ 

## (d) Setting Branch Destination Address of Exception Handling Routine in PC

Processing is shifted to the exception handling routine by acquiring the vector corresponding to the exception and then branching accordingly.

## (2) Hardware Post-Processing for Execution of RTE and RTFI Instructions

### (a) Restoring PSW

• For a fast interrupt

 $BPSW \rightarrow PSW$ 

• For exceptions other than a fast interrupt

 $Stack \to PSW$ 

### (b) Restoring PC

• For a fast interrupt

 $BPC \rightarrow PC$ 

• For exceptions other than a fast interrupt

 $Stack \rightarrow PC$ 

## 13.5 Hardware Pre-Processing

The hardware pre-processing from reception of each exception request to execution of the associated exception handling routine are explained below.

## 13.5.1 Undefined Instruction Exception

- 1. The value of the processor status word (PSW) is saved on the stack (ISP).
- 2. The processor mode select bit (PM), the stack pointer select bit (U), and the interrupt enable bit (I) in PSW are set to 0.
- 3. The value of the program counter (PC) is saved on the stack (ISP).
- 4. The vector is fetched from address FFFF FFDCh.
- 5. The fetched vector is set to the PC and processing branches to the exception handling routine.

## 13.5.2 Privileged Instruction Exception

- 1. The value in the processor status word (PSW) is saved on the stack (ISP).
- 2. The processor mode select bit (PM), the stack pointer select bit (U), and the interrupt enable bit (I) in PSW are set to 0.
- 3. The value of the program counter (PC) is saved on the stack (ISP).
- 4. The vector is fetched from address FFFF FFD0h.
- 5. The fetched vector is set to the PC and processing branches to the exception handling routine.

### 13.5.3 Reset

- 1. The control registers are initialized.
- 2. The vector is fetched from address FFFF FFFCh.
- 3. The fetched vector is set to the PC.

## 13.5.4 Non-Maskable Interrupt

- 1. The value of the processor status word (PSW) is saved on the stack (ISP).
- 2. The processor mode select bit (PM), the stack pointer select bit (U), and the interrupt enable bit (I) in PSW are set to 0.
- 3. If the interrupt was generated during the execution of an RMPA, SCMPU, SMOVB, SMOVF, SMOVU, SSTR, SUNTIL, or SWHILE instruction, the value of the program counter (PC) for that instruction is saved on the stack (ISP). For other instructions, the PC value of the next instruction is saved.
- 4. The processor interrupt priority level bits (IPL[3:0]) in PSW are set to Fh.
- 5. The vector is fetched from address FFFF FFF8h.
- 6. The fetched vector is set to the PC and processing branches to the exception handling routine.



### 13.5.5 Interrupt

1. The value of the processor status word (PSW) is saved on the stack (ISP) or, for the fast interrupt, in the backup PSW (BPSW).

- 2. The processor mode select bit (PM), the stack pointer select bit (U), and the interrupt enable bit (I) in PSW are set to 0.
- 3. If the interrupt was generated during the execution of an RMPA, SCMPU, SMOVB, SMOVF, SMOVU, SSTR, SUNTIL, or SWHILE instruction, the value of the program counter (PC) for that instruction is saved. For other instructions, the PC value of the next instruction is saved. Saving of the PC is in the backup PC (BPC) for fast interrupts.
- 4. The processor interrupt priority level bits (IPL[3:0]) in PSW indicate the interrupt priority level of the interrupt.
- 5. The vector for an interrupt source other than the fast interrupt is fetched from the relocatable vector table. For the fast interrupt, the address is fetched from the fast interrupt vector register (FINTV).
- 6. The fetched vector is set to the PC and processing branches to the exception handling routine.

### 13.5.6 Unconditional Trap

- 1. The value in the processor status word (PSW) is saved on the stack (ISP).
- 2. The processor mode select bit (PM), the stack pointer select bit (U), and the interrupt enable bit (I) in PSW are set to 0.
- 3. The value of the program counter (PC) for the next instruction is saved on the stack (ISP).
- 4. For the INT instruction, the value at the vector corresponding to the INT instruction number is fetched from the relocatable vector table.
  - For the BRK instruction, the value at the vector from the start address is fetched from the relocatable vector table.
- 5. The fetched vector is set to the PC and processing branches to the exception handling routine.



## 13.6 Return from Exception Handling Routine

Executing the instruction listed in Table 13.3 at the end of the corresponding exception handling routine restores the values of the program counter (PC) and processor status word (PSW) that were saved on the stack or in the control registers (BPC and BPSW) immediately before the exception handling sequence.

Table 13.3 Return from Exception Handling Routine

| Exception                       |                  | Instruction for Return |  |
|---------------------------------|------------------|------------------------|--|
| Undefined instruction exception |                  | RTE                    |  |
| Privileged instruction exce     | ption            | RTE                    |  |
| Reset                           |                  | Return is impossible   |  |
| Non-maskable interrupt          |                  | Return is impossible   |  |
| Interrupt                       | Fast interrupt   | RTFI                   |  |
|                                 | Other than above | RTE                    |  |
| Unconditional trap              |                  | RTE                    |  |

## 13.7 Priority of Exception Events

The priority of exception events is listed in Table 13.4. When multiple exceptions are generated at the same time, the exception with the highest priority is accepted first.

Table 13.4 Priority of Exception Events

| Priority |   | Exception Event                                                  |  |
|----------|---|------------------------------------------------------------------|--|
| High     | 1 | Reset                                                            |  |
| <b>↑</b> | 2 | Non-maskable interrupt                                           |  |
|          | 3 | Interrupt                                                        |  |
|          | 4 | Undefined instruction exception Privileged instruction exception |  |
| Low      | 5 | Unconditional trap                                               |  |

# 14. Interrupt Controller (ICUb)

In this section, "PCLK" is used to refer to PCLKB.

### 14.1 Overview

The interrupt controller receives interrupt signals from peripheral modules and external pins, sends interrupts to the CPU, and activates the DTC.

Table 14.1 lists the specifications of the interrupt controller, and Figure 14.1 shows a block diagram of the interrupt controller.

Table 14.1 Specifications of Interrupt Controller

| Item                           |                                      | Description                                                                                                                                                                                                                                                                    |                                                                                                            |  |
|--------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|--|
| Interrupts                     | Peripheral function interrupts       | <ul> <li>Interrupts from peripheral modules</li> <li>Interrupt detection: Edge detection/level detection</li> <li>Edge detection or level detection is fixed for each source of connected peripheral modules.</li> </ul>                                                       |                                                                                                            |  |
|                                | External pin interrupts              | <ul> <li>Interrupts from pins IRQ0 to IRQ7</li> <li>Number of sources: 8</li> <li>Interrupt detection: Low/falling edge/rising edge/rising and falling edges One of these detection methods can be set for each source.</li> <li>Digital filter function: Supported</li> </ul> |                                                                                                            |  |
|                                | Software interrupt                   | <ul><li>Interrupt generated by writing to a register</li><li>One interrupt source</li></ul>                                                                                                                                                                                    |                                                                                                            |  |
|                                | Interrupt priority                   | Specified by registers.                                                                                                                                                                                                                                                        |                                                                                                            |  |
|                                | Fast interrupt function              | Faster interrupt handling of the CPU can be set only for a single interrupt source.                                                                                                                                                                                            |                                                                                                            |  |
|                                | DTC control                          | The DTC can be activated by interrupt sources.*1                                                                                                                                                                                                                               |                                                                                                            |  |
| Non-<br>maskable<br>interrupts | NMI pin interrupt                    | <ul> <li>Interrupt from the NMI pin</li> <li>Interrupt detection: Falling edge/rising edge</li> <li>Digital filter function: Supported</li> </ul>                                                                                                                              |                                                                                                            |  |
|                                | Oscillation stop detection interrupt | Interrupt on detection of oscillation having stopped                                                                                                                                                                                                                           |                                                                                                            |  |
|                                | IWDT underflow/<br>refresh error     | Interrupt on an underflow of the down counter or occurrence of a refresh error                                                                                                                                                                                                 |                                                                                                            |  |
|                                | Voltage monitoring<br>1 interrupt    | Voltage monitoring interrupt of voltage monitoring circuit 1 (LVD1)                                                                                                                                                                                                            |                                                                                                            |  |
|                                | Voltage monitoring 2 interrupt       | Voltage monitoring interrupt of voltage monitoring circuit 2 (LVD2)                                                                                                                                                                                                            |                                                                                                            |  |
| Return from                    | n power-down                         | , , , , ,                                                                                                                                                                                                                                                                      | Return is initiated by non-maskable interrupts or any other interrupt source.                              |  |
|                                |                                      | Software standby mode:                                                                                                                                                                                                                                                         | Return is initiated by non-maskable interrupts, IRQ0 to IRQ7 interrupts, or RTC alarm/periodic interrupts. |  |

Note 1. For the DTC activation source, see Table 14.3, Interrupt Vector Table.



Figure 14.1 Block Diagram of Interrupt Controller

Table 14.2 lists the I/O pins of the interrupt controller.

Table 14.2 Pin Configuration of Interrupt Controller

| Pin Name     | I/O   | Description                        |
|--------------|-------|------------------------------------|
| NMI          | Input | Non-maskable interrupt request pin |
| IRQ0 to IRQ7 | Input | External interrupt request pins    |

#### 14.2 Register Descriptions

#### 14.2.1 Interrupt Request Register n (IRn) (n = interrupt vector number)

Address(es): 0008 7010h to 0008 70F9h



| Bit      | Symbol | Bit Name              | Description                                            | R/W         |
|----------|--------|-----------------------|--------------------------------------------------------|-------------|
| b0       | IR     | Interrupt Status Flag | Interrupt not requested     Interrupt requested        | R/(W)<br>*1 |
| b7 to b1 | _      | Reserved              | These bits are read as 0. The write value should be 0. | R/W         |

Note 1. For an edge detection interrupt, only 0 can be written to this bit; do not write 1. For a level detection interrupt, neither 0 nor 1 can be written.

IRn is provided for each interrupt source, where "n" indicates the interrupt vector number.

For the correspondence between interrupt sources and interrupt vector numbers, see Table 14.3, Interrupt Vector Table.

#### IR Flag (Interrupt Status Flag)

This bit is the status flag of an individual interrupt request. This flag is set to 1 when the corresponding interrupt request is generated. To detect an interrupt request, the interrupt request output should be enabled by the corresponding peripheral module interrupt enable bit.

There are two interrupt request detection methods: edge detection and level detection. For interrupts from peripheral modules, either edge detection or level detection is determined for each interrupt source. For interrupts from IRQi pins, edge detection or level detection is selected by setting the corresponding IRQCRi.IRQMD[1:0] bits (i = 0 to 7). For detection of the various interrupt sources, see Table 14.3, Interrupt Vector Table.

#### (1) Edge detection

[Setting condition]

• The flag is set to 1 in response to the generation of an interrupt request from the corresponding peripheral module or IRQi pin. For interrupt generation by the various peripheral modules, refer to the sections describing the modules.

#### [Clearing conditions]

- The flag is set to 0 when the interrupt request destination accepts the interrupt request.
- The IR flag is set to 0 by writing 0 to it. Note, however, that writing 0 to the IR flag is prohibited if the destination of the interrupt request is the DTC.

#### (2) Level detection

[Setting condition]

• The flag remains set to 1 while an interrupt request is being sent from the corresponding peripheral module or IRQi pin. For interrupt generation by the various peripheral modules, refer to the sections describing the modules.

### [Clearing condition]

• The flag is set to 0 when the source of the interrupt request is cleared (it is not cleared when the interrupt request destination accepts the interrupt request). For clearing interrupts from the various peripheral modules, refer to the sections describing the modules.

When level detection has been selected for an IRQi pin, the interrupt request is withdrawn by driving the IRQi pin high. Do not write 0 or 1 to the IR flag while level detection is selected.



## 14.2.2 Interrupt Request Enable Register m (IERm) (m = 02h to 1Fh)

Address(es): 0008 7202h to 0008 721Fh



| Bit | Symbol | Bit Name                   | Description                      | R/W |
|-----|--------|----------------------------|----------------------------------|-----|
| b0  | IEN0   | Interrupt Request Enable 0 | 0: Interrupt request is disabled | R/W |
| b1  | IEN1   | Interrupt Request Enable 1 | 1: Interrupt request is enabled  | R/W |
| b2  | IEN2   | Interrupt Request Enable 2 | <del></del>                      | R/W |
| b3  | IEN3   | Interrupt Request Enable 3 | _                                | R/W |
| b4  | IEN4   | Interrupt Request Enable 4 | <del></del>                      | R/W |
| b5  | IEN5   | Interrupt Request Enable 5 | <del></del>                      | R/W |
| b6  | IEN6   | Interrupt Request Enable 6 | -                                | R/W |
| b7  | IEN7   | Interrupt Request Enable 7 | <del></del>                      | R/W |

Note: Write 0 to the bit that corresponds to the vector number for reservation. These bits are read as 0.

#### IENj Bit (Interrupt Request Enable j) (j = 0 to 7)

When an IENj bit is 1, the corresponding interrupt request will be output to the destination selected for the request. When an IENj bit is 0, the corresponding interrupt request will not be output to the destination selected for the request. The setting of an IENj bit does not affect the IRn.IR flag. Even if the corresponding IENj bit is 0, the IR flag value changes according to the descriptions in section 14.2.1, Interrupt Request Register n (IRn) (n = interrupt vector number).

The IERm.IENi bit is set for each request source (vector number).

For the correspondence between interrupt sources and IERm.IENj bit, see Table 14.3, Interrupt Vector Table. For the procedure for setting IERm.IENj bit during the selection of destinations for interrupt requests, refer to section 14.4.3, Selecting Interrupt Request Destinations.

## 14.2.3 Interrupt Source Priority Register n (IPRn) (n = 000 to 249)

Address(es): 0008 7300h to 0008 73F9h



| Bit      | Symbol   | Bit Name                        | Description                                                                                                                                                                                          | R/W |
|----------|----------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0 | IPR[3:0] | Interrupt Priority Level Select | b3 b0 0 0 0: Level 0 (interrupt disabled)*1 0 0 0 1: Level 1 0 0 1 0: Level 2 0 0 1 1: Level 3 0 1 0 0: Level 4 0 1 0 1: Level 5 0 1 1 0: Level 6 0 1 1 1: Level 7 1 0 0 0: Level 8 1 0 0 1: Level 9 | R/W |
|          |          |                                 | 1 0 1 0: Level 10<br>1 0 1 1: Level 11                                                                                                                                                               |     |
|          |          |                                 | 1                                                                                                                                                                                                    |     |
|          |          |                                 | 1 1 1 1: Level 15 (highest)                                                                                                                                                                          |     |
| b7 to b4 | _        | Reserved                        | These bits are read as 0. The write value should be 0.                                                                                                                                               | R/W |

Note 1. When the interrupt is specified as a fast interrupt, it can be issued even if the priority level is level 0.

For the correspondence between interrupt sources and IPRn register, see Table 14.3, Interrupt Vector Table.

#### IPR[3:0] Bits (Interrupt Priority Level Select)

These bits specify the priority level of the corresponding interrupt source.

Priority levels specified by the IPR[3:0] bits are used only to determine the priority of interrupt requests to be transferred to the CPU, and do not affect activation requests to the DTC.

The CPU accepts only interrupt requests higher than the priority level specified by the PSW.IPL[3:0] bits, and handles accepted interrupts.

If two or more interrupt requests are generated at the same time, their priority levels are compared with the value of the IPR[3:0] bits. If interrupt requests of the same priority level are generated at the same time, an interrupt source with a smaller vector number takes precedence.

These bits should be written to while an interrupt request is disabled (IERm.IEN) bit = 0).

## 14.2.4 Fast Interrupt Set Register (FIR)

Address(es): 0008 72F0h



| Bit       | Symbol    | Bit Name                     | Description                                                              | R/W |
|-----------|-----------|------------------------------|--------------------------------------------------------------------------|-----|
| b7 to b0  | FVCT[7:0] | Fast Interrupt Vector Number | Specify the vector number of an interrupt source to be a fast interrupt. | R/W |
| b14 to b8 | _         | Reserved                     | These bits are read as 0. The write value should be 0.                   | R/W |
| b15       | FIEN      | Fast Interrupt Enable        | Fast interrupt is disabled     Fast interrupt is enabled                 | R/W |

The fast interrupt function based on the FIR register setting is applicable only to interrupts to the CPU. It will not affect any transfer request to the DTC.

Before writing to this register, be sure to disable interrupt requests (IERm.IENj bit = 0).

#### FVCT[7:0] Bits (Fast Interrupt Vector Number)

The FVCT[7:0] bits specify the vector number of an interrupt source that uses the fast interrupt function.

#### **FIEN Bit (Fast Interrupt Enable)**

This bit enables the fast interrupt.

Setting this bit to 1 makes the interrupt request of the vector number specified by the FVCT[7:0] bits a fast interrupt. When an interrupt request of the vector number specified by the FVCT[7:0] bits is generated and the interrupt request destination is the CPU while the FIEN bit is 1, the interrupt request is output to the CPU as a fast interrupt regardless of the setting of the IPRn register. When using the fast interrupt for returning from the software standby mode, refer to section 14.6.2, Return from Software Standby Mode.

If the setting of the IERm.IENj (m = 02h to 1Fh; j = 0 to 7) bit has disabled interrupt requests from the interrupt source with the vector number in this register, fast interrupt requests are not output to the CPU.

For settable vector numbers, see Table 14.3, Interrupt Vector Table.

Do not write any reserved vector numbers to the FVCT[7:0] bits.

For details on the fast interrupt, refer to section 13, Exception Handling, and section 14.4.6, Fast Interrupt.

## 14.2.5 Software Interrupt Activation Register (SWINTR)

Address(es): 0008 72E0h



| Bit      | Symbol | Bit Name                      | Description                                                                                                | R/W         |
|----------|--------|-------------------------------|------------------------------------------------------------------------------------------------------------|-------------|
| b0       | SWINT  | Software Interrupt Activation | This bit is read as 0. Writing 1 issues a software interrupt request. Writing 0 to this bit has no effect. | R/(W)<br>*1 |
| b7 to b1 | _      | Reserved                      | These bits are read as 0. The write value should be 0.                                                     | R/W         |

Note 1. Only 1 can be written.

#### **SWINT Bit (Software Interrupt Activation)**

When 1 is written to the SWINT bit, interrupt request register 027 (IR027) is set to 1.

If 1 is written to the SWINT bit when DTC activation enable register 027 (DTCER027) is set to 0, an interrupt to the CPU is generated.

If 1 is written to the SWINT bit when DTC activation enable register 027 (DTCER027) is set to 1, a DTC activation request is issued.

# 14.2.6 DTC Activation Enable Register n (DTCERn) (n = interrupt vector number)

Address(es): 0008 711Bh to 0008 71F8h



| Bit      | Symbol | Bit Name              | Description                                              | R/W |
|----------|--------|-----------------------|----------------------------------------------------------|-----|
| b0       | DTCE   | DTC Activation Enable | DTC activation is disabled     DTC activation is enabled | R/W |
| b7 to b1 | _      | Reserved              | These bits are read as 0. The write value should be 0.   | R/W |

See Table 14.3, Interrupt Vector Table, for the interrupt sources that are selectable as sources for DTC activation.

#### **DTCE Bit (DTC Activation Enable)**

When the DTCE bit is set to 1, the corresponding interrupt source is selected as the source for the DTC activation.

[Setting condition]

• When 1 is written to the DTCE bit

[Clearing conditions]

- When the specified number of transfers is completed (for the chain transfer, the number of transfers for the last chain transfer is completed)
- When 0 is written to the DTCE bit

## 14.2.7 IRQ Control Register i (IRQCRi) (i = 0 to 7)

Address(es): 0008 7500h to 0008 7507h



| Bit      | Symbol     | Bit Name                      | Description                                                                           | R/W |
|----------|------------|-------------------------------|---------------------------------------------------------------------------------------|-----|
| b1, b0   | _          | Reserved                      | These bits are read as 0. The write value should be 0.                                | R/W |
| b3, b2   | IRQMD[1:0] | IRQ Detection Sense<br>Select | b3 b2 0 0: Low level 0 1: Falling edge 1 0: Rising edge 1 1: Rising and falling edges | R/W |
| b7 to b4 | _          | Reserved                      | These bits are read as 0. The write value should be 0.                                | R/W |

Only change the settings of this register while the corresponding interrupt request enable bit is prohibiting the interrupt request (IERm.IENj bit is 0). After changing the setting, clear the IR flag before setting the interrupt enable bit. However, when the change is to the low level, the IR flag does not require clearing.

### IRQMD[1:0] Bits (IRQ Detection Sense Select)

These bits select the detection sensing method of external pin interrupt sources IRQ0 to IRQ7. For the external pin interrupt detection setting, refer to section 14.4.8, External Pin Interrupts.

## 14.2.8 IRQ Pin Digital Filter Enable Register 0 (IRQFLTE0)

Address(es): 0008 7510h



| Bit | Symbol | Bit Name                   | Description                | R/W |
|-----|--------|----------------------------|----------------------------|-----|
| b0  | FLTEN0 | IRQ0 Digital Filter Enable | 0: Digital filter disabled | R/W |
| b1  | FLTEN1 | IRQ1 Digital Filter Enable | 1: Digital filter enabled  | R/W |
| b2  | FLTEN2 | IRQ2 Digital Filter Enable | <u> </u>                   | R/W |
| b3  | FLTEN3 | IRQ3 Digital Filter Enable | <u> </u>                   | R/W |
| b4  | FLTEN4 | IRQ4 Digital Filter Enable | <u> </u>                   | R/W |
| b5  | FLTEN5 | IRQ5 Digital Filter Enable | <u> </u>                   | R/W |
| b6  | FLTEN6 | IRQ6 Digital Filter Enable | <u> </u>                   | R/W |
| b7  | FLTEN7 | IRQ7 Digital Filter Enable |                            | R/W |

#### FLTENi Bit (IRQi Digital Filter Enable) (i = 0 to 7)

These bits enable the digital filter used for the external pin interrupt sources IRQ0 to IRQ7.

The digital filter is enabled when the FLTENi bit is 1, and disabled when the FLTENi bit is 0.

The IRQi pin level is sampled at the sampling clock cycle specified with the IRQFLTC0.FCLKSELi[1:0] bits. When the sampled level matches three times, the output level from the digital filter changes.

For details of the digital filter, refer to section 14.4.7, Digital Filter.

## 14.2.9 IRQ Pin Digital Filter Setting Register 0 (IRQFLTC0)

Address(es): 0008 7514h



| Bit      | Symbol        | Bit Name                           | Description                 | R/W |
|----------|---------------|------------------------------------|-----------------------------|-----|
| b1, b0   | FCLKSEL0[1:0] | IRQ0 Digital Filter Sampling Clock | 0 0: PCLK                   | R/W |
| b3, b2   | FCLKSEL1[1:0] | IRQ1 Digital Filter Sampling Clock | 0 1: PCLK/8<br>1 0: PCLK/32 | R/W |
| b5, b4   | FCLKSEL2[1:0] | IRQ2 Digital Filter Sampling Clock | 1 1: PCLK/64                | R/W |
| b7, b6   | FCLKSEL3[1:0] | IRQ3 Digital Filter Sampling Clock |                             | R/W |
| b9, b8   | FCLKSEL4[1:0] | IRQ4 Digital Filter Sampling Clock |                             | R/W |
| b11, b10 | FCLKSEL5[1:0] | IRQ5 Digital Filter Sampling Clock |                             | R/W |
| b13, b12 | FCLKSEL6[1:0] | IRQ6 Digital Filter Sampling Clock |                             | R/W |
| b15, b14 | FCLKSEL7[1:0] | IRQ7 Digital Filter Sampling Clock |                             | R/W |

#### FCLKSELi[1:0] Bits (IRQi Digital Filter Sampling Clock) (i = 0 to 7)

These bits select the cycle of the digital filter sampling clock for the external pin interrupt request pins IRQ0 to IRQ7. The sampling clock cycle can be selected from among the PCLK (every cycle), PCLK/8 (once every eight cycles), PCLK/32 (once every 32 cycles), and PCLK/64 (once every 64 cycles).

For details of the digital filter, refer to section 14.4.7, Digital Filter.

## 14.2.10 Non-Maskable Interrupt Status Register (NMISR)

Address(es): 0008 7580h



| Bit    | Symbol | Bit Name                                            | Description                                                                                                     | R/W |
|--------|--------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-----|
| b0     | NMIST  | NMI Status Flag                                     | NMI pin interrupt is not requested     NMI pin interrupt is requested                                           | R   |
| b1     | OSTST  | Oscillation Stop Detection<br>Interrupt Status Flag | Oscillation stop detection interrupt is not requested     Secillation stop detection interrupt is requested     | R   |
| b2     | _      | Reserved                                            | This bit is read as 0 and cannot be modified.                                                                   | R   |
| b3     | IWDTST | IWDT Underflow/Refresh<br>Error Status Flag         | IWDT underflow/refresh error interrupt is not requested     IWDT underflow/refresh error interrupt is requested | R   |
| b4     | LVD1ST | Voltage Monitoring 1<br>Interrupt Status Flag       | Voltage monitoring 1 interrupt is not requested     Voltage monitoring 1 interrupt is requested                 | R   |
| b5     | LVD2ST | Voltage Monitoring 2<br>Interrupt Status Flag       | Voltage monitoring 2 interrupt is not requested     Voltage monitoring 2 interrupt is requested                 | R   |
| b7, b6 | _      | Reserved                                            | These bits are read as 0 and cannot be modified.                                                                | R   |

The NMISR register monitors the status of a non-maskable interrupt source. Writing to the NMISR register is ignored. The setting in the non-maskable interrupt enable register (NMIER) does not affect the status flags in NMISR. Before the end of the non-maskable interrupt handler, read the NMISR register and confirm the generation status of other non-maskable interrupts. Be sure to confirm that all of the bits in the NMISR register are set to 0 before the end of the handler.

#### **NMIST Flag (NMI Status Flag)**

This flag indicates the NMI pin interrupt request.

The NMIST flag is read-only, and cleared by the NMICLR.NMICLR bit. [Setting condition]

- When an edge specified by the NMICR.NMIMD bit is input to the NMI pin [Clearing condition]
  - When 1 is written to the NMICLR.NMICLR bit

#### **OSTST Flag (Oscillation Stop Detection Interrupt Status Flag)**

This flag indicates the oscillation stop detection interrupt request.

The OSTST flag is read-only, and cleared by the NMICLR.OSTCLR bit.

[Setting condition]

- When the oscillation stop detection interrupt is generated [Clearing condition]
- When 1 is written to the NMICLR.OSTCLR bit



#### IWDTST Flag (IWDT Underflow/Refresh Error Status Flag)

This flag indicates the IWDT underflow/refresh error interrupt request.

The IWDTST flag is read-only, and cleared by the NMICLR.IWDTCLR bit.

[Setting condition]

• When the IWDT underflow/refresh error interrupt is generated while this interrupt is enabled at its source.

[Clearing condition]

• When 1 is written to the NMICLR.IWDTCLR bit

#### LVD1ST Flag (Voltage Monitoring 1 Interrupt Status Flag)

This flag indicates the request for voltage monitoring 1 interrupt.

The LVD1ST flag is read-only, and cleared by the NMICLR.LVD1CLR bit.

[Setting condition]

• When the voltage monitoring 1 interrupt is generated while this interrupt is enabled at its source.

[Clearing condition]

• When 1 is written to the NMICLR.LVD1CLR bit

#### LVD2ST Flag (Voltage Monitoring 2 Interrupt Status Flag)

This flag indicates the request for voltage monitoring 2 interrupt.

The LVD2ST flag is read-only, and cleared by the NMICLR.LVD2CLR bit.

[Setting condition]

• When the voltage monitoring 2 interrupt is generated while this interrupt is enabled at its source.

[Clearing condition]

• When 1 is written to the NMICLR.LVD2CLR bit

## 14.2.11 Non-Maskable Interrupt Enable Register (NMIER)

Address(es): 0008 7581h



| Bit    | Symbol | Bit Name                                    | Description                                                                                                | R/W         |
|--------|--------|---------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------|
| b0     | NMIEN  | NMI Pin Interrupt Enable                    | 0: NMI pin interrupt is disabled 1: NMI pin interrupt is enabled                                           | R/(W)<br>*1 |
| b1     | OSTEN  | Oscillation Stop Detection Interrupt Enable | Oscillation stop detection interrupt is disabled     Socillation stop detection interrupt is enabled       | R/(W)<br>*1 |
| b2     | _      | Reserved                                    | This bit is read as 0. The write value should be 0.                                                        | R/(W)       |
| b3     | IWDTEN | IWDT Underflow/Refresh Error<br>Enable      | 0: IWDT underflow/refresh error interrupt is disabled 1: IWDT underflow/refresh error interrupt is enabled | R/(W)<br>*1 |
| b4     | LVD1EN | Voltage Monitoring 1 Interrupt<br>Enable    | Voltage monitoring 1 interrupt is disabled     Voltage monitoring 1 interrupt is enabled                   | R/(W)<br>*1 |
| b5     | LVD2EN | Voltage Monitoring 2 Interrupt<br>Enable    | Voltage monitoring 2 interrupt is disabled     Voltage monitoring 2 interrupt is enabled                   | R/(W)<br>*1 |
| b7, b6 | _      | Reserved                                    | These bits are read as 0. The write value should be 0.                                                     | R/W         |

Note 1. 1 can be written to this bit only once, and subsequent write accesses are no longer enabled.

#### **NMIEN Bit (NMI Pin Interrupt Enable)**

This bit enables the NMI pin interrupt.

A 1 can be written to this bit only once, and subsequent write accesses are no longer enabled.

Writing 0 to this bit is disabled.

#### **OSTEN Bit (Oscillation Stop Detection Interrupt Enable)**

This bit enables the oscillation stop detection interrupt.

A 1 can be written to this bit only once, and subsequent write accesses are no longer enabled.

Writing 0 to this bit is disabled.

#### **IWDTEN Bit (IWDT Underflow/Refresh Error Enable)**

This bit enables the IWDT underflow/refresh error interrupt.

A 1 can be written to this bit only once, and subsequent write accesses are no longer enabled.

Writing 0 to this bit is disabled.

#### LVD1EN Bit (Voltage Monitoring 1 Interrupt Enable)

This bit enables the voltage monitoring 1 interrupt.

A 1 can be written to this bit only once, and subsequent write accesses are no longer enabled.

Writing 0 to this bit is disabled.

#### LVD2EN Bit (Voltage Monitoring 2 Interrupt Enable)

This bit enables the voltage monitoring 2 interrupt.

A 1 can be written to this bit only once, and subsequent write accesses are no longer enabled.

Writing 0 to this bit is disabled.



## 14.2.12 Non-Maskable Interrupt Status Clear Register (NMICLR)

Address(es): 0008 7582h



| Bit    | Symbol  | Bit Name   | Description                                                                                                     | R/W         |
|--------|---------|------------|-----------------------------------------------------------------------------------------------------------------|-------------|
| b0     | NMICLR  | NMI Clear  | This bit is read as 0. Writing 1 to this bit clears the NMISR.NMIST flag. Writing 0 to this bit has no effect.  | R/(W)<br>*1 |
| b1     | OSTCLR  | OST Clear  | This bit is read as 0. Writing 1 to this bit clears the NMISR.OSTST flag. Writing 0 to this bit has no effect.  | R/(W)<br>*1 |
| b2     | _       | Reserved   | This bit is read as 0. The write value should be 0.                                                             | R/(W)       |
| b3     | IWDTCLR | IWDT Clear | This bit is read as 0. Writing 1 to this bit clears the NMISR.IWDTST flag. Writing 0 to this bit has no effect. | R/(W)<br>*1 |
| b4     | LVD1CLR | LVD1 Clear | This bit is read as 0. Writing 1 to this bit clears the NMISR.LVD1ST flag. Writing 0 to this bit has no effect. | R/(W)<br>*1 |
| b5     | LVD2CLR | LVD2 Clear | This bit is read as 0. Writing 1 to this bit clears the NMISR.LVD2ST flag. Writing 0 to this bit has no effect. | R/(W)<br>*1 |
| b7, b6 | _       | Reserved   | These bits are read as 0. The write value should be 0.                                                          | R/W         |

Note 1. Only 1 can be written to this bit.

#### **NMICLR Bit (NMI Clear)**

Writing 1 to the NMICLR bit clears the NMISR.NMIST flag. This bit is read as 0.

### **OSTCLR Bit (OST Clear)**

Writing 1 to the OSTCLR bit clears the NMISR.OSTST flag. This bit is read as 0.

#### **IWDTCLR Bit (IWDT Clear)**

Writing 1 to the IWDTCLR bit clears the NMISR.IWDTST flag. This bit is read as 0.

### LVD1CLR Bit (LVD1 Clear)

Writing 1 to the LVD1CLR bit clears the NMISR.LVD1ST flag. This bit is read as 0.

### LVD2CLR Bit (LVD2 Clear)

Writing 1 to the LVD2CLR bit clears the NMISR.LVD2ST flag. This bit is read as 0.

## 14.2.13 NMI Pin Interrupt Control Register (NMICR)

Address(es): 0008 7583h



| Bit      | Symbol | Bit Name          | Description                                            | R/W |
|----------|--------|-------------------|--------------------------------------------------------|-----|
| b2 to b0 | _      | Reserved          | These bits are read as 0. The write value should be 0. | R/W |
| b3       | NMIMD  | NMI Detection Set | 0: Falling edge<br>1: Rising edge                      | R/W |
| b7 to b4 | _      | Reserved          | These bits are read as 0 and cannot be modified.       | R/W |

Change the setting of the NMICR register before the NMI pin interrupt is enabled (before setting the NMIER.NMIEN bit to 1).

#### **NMIMD Bit (NMI Detection Set)**

This bit specifies the detection edge of the NMI pin interrupt.

## 14.2.14 NMI Pin Digital Filter Enable Register (NMIFLTE)

Address(es): 0008 7590h



| Bit      | Symbol | Bit Name                  | Description                                            | R/W |
|----------|--------|---------------------------|--------------------------------------------------------|-----|
| b0       | NFLTEN | NMI Digital Filter Enable | Digital filter disabled     Digital filter enabled     | R/W |
| b7 to b1 | _      | Reserved                  | These bits are read as 0. The write value should be 0. | R/W |

#### **NFLTEN Bit (NMI Digital Filter Enable)**

This bit enables the digital filter used for the NMI pin interrupt.

The digital filter is enabled when the NFLTEN bit is 1, and disabled when the NFLTEN bit is 0.

The NMI pin level is sampled at the sampling clock cycle specified with the NMIFLTC.NFCLKSEL[1:0] bits. When the sampled level matches three times, the output level from the digital filter changes.

For details of the digital filter, refer to section 14.4.7, Digital Filter.

## 14.2.15 NMI Pin Digital Filter Setting Register (NMIFLTC)

Address(es): 0008 7594h



| Bit      | Symbol        | Bit Name                             | Description                                                       | R/W |
|----------|---------------|--------------------------------------|-------------------------------------------------------------------|-----|
| b1, b0   | NFCLKSEL[1:0] | NMI Digital Filter Sampling<br>Clock | b1 b0<br>0 0: PCLK<br>0 1: PCLK/8<br>1 0: PCLK/32<br>1 1: PCLK/64 | R/W |
| b7 to b2 | _             | Reserved                             | These bits are read as 0. The write value should be 0.            | R/W |

### NFCLKSEL[1:0] Bits (NMI Digital Filter Sampling Clock)

These bits select the cycle of the digital filter sampling clock for the NMI pin interrupt.

The sampling clock cycle can be selected from among the PCLK (every cycle), PCLK/8 (once every eight cycles),

PCLK/32 (once every 32 cycles), and PCLK/64 (once every 64 cycles).

For details of the digital filter, refer to section 14.4.7, Digital Filter.

#### 14.3 Vector Table

There are two types of interrupts detected by the interrupt controller: maskable interrupts and non-maskable interrupts. When the CPU accepts an interrupt or non-maskable interrupt, it acquires a 4-byte vector address from the vector table.

## 14.3.1 Interrupt Vector Table

The interrupt vector table is placed in the 1024-byte range (4 bytes  $\times$  256 sources) beginning at the address specified in the interrupt table register (INTB) of the CPU. Write a value to the INTB register before enabling interrupts. The value written to the INTB register should be a multiple of 4.

Executing an INT instruction or BRK instruction leads to the generation of an unconditional trap. The same range of memory as shown in Table 14.3, Interrupt Vector Table, is used for the vectors for unconditional traps. The vector for BRK instructions is vector 0 while the vector numbers for INT instructions are specifiable as numbers in the range from 0 to 255.

Table 14.3 lists details of the interrupt vectors. Details of the headings in Table 14.3 are listed below.

| Item                                   | Description                                                                                    |
|----------------------------------------|------------------------------------------------------------------------------------------------|
| Source of interrupt request generation | Name of the source for generation of the interrupt request                                     |
| Name                                   | Name of the interrupt                                                                          |
| Vector no.                             | Vector number for the interrupt                                                                |
| Vector address offset                  | Value of the offset from the base address for the vector table                                 |
| Form of interrupt detection            | "Edge" or "level" as the method for detection of the interrupt                                 |
| CPU interrupt                          | "o" in this column indicates usability as a CPU interrupt.                                     |
| DTC activation                         | "o" in this column indicates usability as a request for DTC activation.                        |
| sstb return                            | "o" in this column indicates usability as a request for return from software standby mode.     |
| IER                                    | Name of the interrupt request enable register (IER) and bit corresponding to the vector number |
| IPR                                    | Name of the interrupt source priority register (IPR) corresponding to the interrupt source     |
| DTCER                                  | Name of the DTC activation enable register (DTCER) corresponding to the DTC activation source  |

Table 14.3 Interrupt Vector Table (1/7)

| Source of<br>Interrupt<br>Request<br>Generation | Name                      | Vector<br>No.*1 | Vector<br>Address<br>Offset | Form of<br>Interrupt<br>Detection | СРИ | DTC | sstb<br>Return | IER        | IPR    | DTCER        |
|-------------------------------------------------|---------------------------|-----------------|-----------------------------|-----------------------------------|-----|-----|----------------|------------|--------|--------------|
| _                                               | For an unconditional trap | 0               | 0000h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 1               | 0004h                       |                                   | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 2               | 0008h                       | _                                 | ×   | ×   | ×              | _          | _      |              |
| _                                               | For an unconditional trap | 3               | 000Ch                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 4               | 0010h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 5               | 0014h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 6               | 0018h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 7               | 001Ch                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 8               | 0020h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 9               | 0024h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 10              | 0028h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 11              | 002Ch                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 12              | 0030h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 13              | 0034h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 14              | 0038h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | For an unconditional trap | 15              | 003Ch                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| BSC                                             | BUSERR                    | 16              | 0040h                       | Level                             | 0   | ×   | ×              | IER02.IEN0 | IPR000 | <u> </u>     |
| _                                               | Reserved                  | 17              | 0044h                       | _                                 | ×   | ×   | ×              | _          | _      | <u>†</u>     |
| _                                               | Reserved                  | 18              | 0048h                       | _                                 | ×   | ×   | ×              | _          | _      | <del> </del> |
| _                                               | Reserved                  | 19              | 004Ch                       | _                                 | ×   | ×   | ×              | _          | _      | <del> </del> |
|                                                 | Reserved                  | 20              | 0050h                       | _                                 | ×   | ×   | ×              | _          | _      | 1            |

Table 14.3 Interrupt Vector Table (2/7)

| Source of<br>Interrupt<br>Request<br>Generation | Name     | Vector<br>No.*1 | Vector<br>Address<br>Offset | Form of<br>Interrupt<br>Detection | СРИ | DTC | sstb<br>Return | IER        | IPR          | DTCER          |
|-------------------------------------------------|----------|-----------------|-----------------------------|-----------------------------------|-----|-----|----------------|------------|--------------|----------------|
| _                                               | Reserved | 21              | 0054h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 22              | 0058h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| FCU                                             | FRDYI    | 23              | 005Ch                       | Edge                              | 0   | ×   | ×              | IER02.IEN7 | IPR002       | _              |
| _                                               | Reserved | 24              | 0060h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 25              | 0064h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 26              | 0068h                       | _                                 | ×   | ×   | ×              | _          | _            | <u> </u>       |
| ICU                                             | SWINT    | 27              | 006Ch                       | Edge                              | 0   | 0   | ×              | IER03.IEN3 | IPR003       | DTCER02        |
| CMT0                                            | CMI0     | 28              | 0070h                       | Edge                              | 0   | 0   | ×              | IER03.IEN4 | IPR004       | DTCER028       |
| CMT1                                            | CMI1     | 29              | 0074h                       | Edge                              | 0   | 0   | ×              | IER03.IEN5 | IPR005       | DTCER029       |
| _                                               | Reserved | 30              | 0078h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 31              | 007Ch                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| CAC                                             | FERRF    | 32              | 0080h                       | Level                             | 0   | ×   | ×              | IER04.IEN0 | IPR032       | _              |
|                                                 | MENDF    | 33              | 0084h                       | Level                             | 0   | ×   | ×              | IER04.IEN1 | IPR033       | _              |
|                                                 | OVFF     | 34              | 0088h                       | Level                             | 0   | ×   | ×              | IER04.IEN2 | IPR034       | _              |
| _                                               | Reserved | 35              | 008Ch                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 36              | 0090h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 37              | 0094h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 38              | 0098h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 39              | 009Ch                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 40              | 00A0h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 41              | 00A4h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 42              | 00A8h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 43              | 00ACh                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| RSPI0                                           | SPEI0    | 44              | 00B0h                       | Level                             | 0   | ×   | ×              | IER05.IEN4 | IPR044       | _              |
|                                                 | SPRI0    | 45              | 00B4h                       | Edge                              | 0   | 0   | ×              | IER05.IEN5 |              | DTCER04        |
|                                                 | SPTI0    | 46              | 00B8h                       | Edge                              | 0   | 0   | ×              | IER05.IEN6 |              | DTCER046       |
|                                                 | SPII0    | 47              | 00BCh                       | Level                             | 0   | ×   | ×              | IER05.IEN7 |              | _              |
| _                                               | Reserved | 48              | 00D0h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 49              | 00D4h                       | _                                 | ×   | ×   | ×              | _          | _            | <u> </u>       |
| _                                               | Reserved | 50              | 00D8h                       | _                                 | ×   | ×   | ×              | _          | _            | <u> </u>       |
| _                                               | Reserved | 51              | 00DCh                       | _                                 | ×   | ×   | ×              | _          | _            | <u> </u>       |
| _                                               | Reserved | 52              | 00D0h                       | _                                 | ×   | ×   | ×              | _          | _            | <u> </u>       |
| _                                               | Reserved | 53              | 00D4h                       | _                                 | ×   | ×   | ×              | _          | _            | <u> </u>       |
| _                                               | Reserved | 54              | 00D8h                       | _                                 | ×   | ×   | ×              | _          | _            | <u> </u>       |
| _                                               | Reserved | 55              | 00DCh                       | _                                 | ×   | ×   | ×              | _          | _            | <u> </u>       |
|                                                 | Reserved | 56              | 00E0h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| DOC                                             | DOPCF    | 57              | 00E4h                       | Level                             | 0   | ×   | ×              | IER07.IEN1 | IPR057       | <del> </del> — |
|                                                 | Reserved | 58              | 00E8h                       | _                                 | ×   | ×   | ×              | _          | _            | <del> </del>   |
|                                                 | Reserved | 59              | 00ECh                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
|                                                 | Reserved | 60              | 00F0h                       | _                                 | ×   | ×   | ×              | _          | _            | _              |
| _                                               | Reserved | 61              | 00F4h                       | _                                 | ×   | ×   | ×              | _          | _            | 1_             |
| _                                               | Reserved | 62              | 00F8h                       | _                                 | ×   | ×   | ×              | _          | <del> </del> | 1_             |
| RTC                                             | CUP      | 63              | 00FCh                       | Edge                              | 0   | ×   | ×              | IER07.IEN7 | IPR063       | 1_             |

Table 14.3 Interrupt Vector Table (3/7)

| Source of            |          |        |                   |                   |      |     |        |                            |        |          |
|----------------------|----------|--------|-------------------|-------------------|------|-----|--------|----------------------------|--------|----------|
| Interrupt<br>Request |          | Vector | Vector<br>Address | Form of Interrupt | 0011 |     | sstb   | .==                        |        | 27072    |
| Generation           | Name     | No.*1  | Offset            | Detection         | CPU  | DTC | Return | IER                        | IPR    | DTCER    |
| ICU                  | IRQ0     | 64     | 0100h             | Edge/Level        | 0    | 0   | 0      | IER08.IEN0                 | IPR064 | DTCER064 |
|                      | IRQ1     | 65     | 0104h             | Edge/Level        | 0    | 0   | 0      | IER08.IEN1                 | IPR065 | DTCER065 |
|                      | IRQ2     | 66     | 0108h             | Edge/Level        | 0    | 0   | 0      | IER08.IEN2                 | IPR066 | DTCER066 |
|                      | IRQ3     | 67     | 010Ch             | Edge/Level        | 0    | 0   | 0      | IER08.IEN3                 | IPR067 | DTCER067 |
|                      | IRQ4     | 68     | 0110h             | Edge/Level        | 0    | 0   | 0      | IER08.IEN4                 | IPR068 | DTCER068 |
|                      | IRQ5     | 69     | 0114h             | Edge/Level        | 0    | 0   | 0      | IER08.IEN5                 | IPR069 | DTCER069 |
|                      | IRQ6     | 70     | 0118h             | Edge/Level        | 0    | 0   | 0      | IER08.IEN6                 | IPR070 | DTCER070 |
|                      | IRQ7     | 71     | 011Ch             | Edge/Level        | 0    | 0   | 0      | IER08.IEN7                 | IPR071 | DTCER071 |
| _                    | Reserved | 72     | 0120h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 73     | 0124h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 74     | 0128h             | _                 | ×    | ×   | ×      | _                          | —      | <u> </u> |
| _                    | Reserved | 75     | 012Ch             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 76     | 0130h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 77     | 0134h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 78     | 0138h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 79     | 013Ch             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 80     | 0140h             | _                 | ×    | ×   | ×      | _                          | _      | 1—       |
| _                    | Reserved | 81     | 0144h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 82     | 0148h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 83     | 014Ch             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 84     | 0150h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 85     | 0154h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 86     | 0158h             | _                 | ×    | ×   | ×      | _                          | _      | 1—       |
| _                    | Reserved | 87     | 015Ch             | _                 | ×    | ×   | ×      | _                          | _      | 1—       |
| LVD                  | LVD1     | 88     | 0160h             | Edge              | 0    | ×   | 0      | IER0B.IEN0                 | IPR088 | 1_       |
|                      | LVD2     | 89     | 0164h             | Edge              | 0    | ×   | 0      | IER0B.IEN1                 | IPR089 | _        |
| _                    | Reserved | 90     | 0168h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 91     | 016Ch             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| RTC                  | ALM      | 92     | 0170h             | Edge              | 0    | ×   | 0      | IER0B.IEN4                 | IPR092 | _        |
|                      | PRD      | 93     | 0174h             | Edge              | 0    | ×   | 0      | IER0B.IEN5                 | IPR093 | 1_       |
| _                    | Reserved | 94     | 0178h             | _                 | ×    | ×   | ×      |                            | _      | _        |
| _                    | Reserved | 95     | 017Ch             | _                 | ×    | ×   | ×      | _                          | _      |          |
| _                    | Reserved | 96     | 0180h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 97     | 0184h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
|                      | Reserved | 98     | 0188h             | _                 | ×    | ×   | ×      | <br>                       | _      | _        |
|                      | Reserved | 99     | 018Ch             |                   | ×    | ×   | ×      | <del>-</del>               |        |          |
| _                    | Reserved | 100    | 0190h             | _                 | ×    | ×   | ×      | <del>-</del><br>  <u>-</u> |        | _        |
| _                    | Reserved | 100    | 0190H             |                   | ×    | ×   | ×      | —<br>  _                   |        | _        |
| S12AD                | S12ADI0  | 101    | 0194n<br>0198h    |                   |      |     |        | IER0C.IEN6                 | IPR102 | DTCER102 |
| SIZAD                |          |        |                   | Edge              | 0    | 0   | ×      |                            |        |          |
|                      | GBADI    | 103    | 019Ch             | Edge              | 0    | 0   | ×      | IER0C.IEN7                 | IPR103 | DTCER103 |
| _                    | Reserved | 104    | 01A0h             | _                 | ×    | ×   | ×      | _                          | _      | _        |
| _                    | Reserved | 105    | 01A4h             | _                 | ×    | ×   | ×      | _                          | _      | <u> </u> |
| _                    | Reserved | 106    | 01A8h             | _                 | ×    | ×   | ×      | _                          | _      |          |

Table 14.3 Interrupt Vector Table (4/7)

| Source of<br>Interrupt<br>Request<br>Generation | Name     | Vector<br>No.*1 | Vector<br>Address<br>Offset | Form of<br>Interrupt<br>Detection | СРИ | DTC | sstb<br>Return | IER        | IPR    | DTCER        |
|-------------------------------------------------|----------|-----------------|-----------------------------|-----------------------------------|-----|-----|----------------|------------|--------|--------------|
| _                                               | Reserved | 107             | 01ACh                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | Reserved | 108             | 01B0h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | Reserved | 109             | 01B4h                       | _                                 | ×   | ×   | ×              | _          | _      | 1-           |
| _                                               | Reserved | 110             | 01B8h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | Reserved | 111             | 01BCh                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | Reserved | 112             | 01C0h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | Reserved | 113             | 01C4h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| MTU0                                            | TGIA0    | 114             | 01C8h                       | Edge                              | 0   | 0   | ×              | IER0E.IEN2 | IPR114 | DTCER114     |
|                                                 | TGIB0    | 115             | 01CCh                       | Edge                              | 0   | 0   | ×              | IER0E.IEN3 |        | DTCER11      |
|                                                 | TGIC0    | 116             | 01D0h                       | Edge                              | 0   | 0   | ×              | IER0E.IEN4 | -      | DTCER110     |
|                                                 | TGID0    | 117             | 01D4h                       | Edge                              | 0   | 0   | ×              | IER0E.IEN5 | -      | DTCER11      |
|                                                 | TCIV0    | 118             | 01D8h                       | Edge                              | 0   | ×   | ×              | IER0E.IEN6 | IPR118 | _            |
|                                                 | TGIE0    | 119             | 01DCh                       | Edge                              | 0   | ×   | ×              | IER0E.IEN7 | -      | _            |
|                                                 | TGIF0    | 120             | 01E0h                       | Edge                              | 0   | ×   | ×              | IER0F.IEN0 | -      | _            |
| MTU1                                            | TGIA1    | 121             | 01E4h                       | Edge                              | 0   | 0   | ×              | IER0F.IEN1 | IPR121 | DTCER12      |
|                                                 | TGIB1    | 122             | 01E8h                       | Edge                              | 0   | 0   | ×              | IER0F.IEN2 | -      | DTCER12      |
|                                                 | TCIV1    | 123             | 01ECh                       | Edge                              | 0   | ×   | ×              | IER0F.IEN3 | IPR123 | _            |
|                                                 | TCIU1    | 124             | 01F0h                       | Edge                              | 0   | ×   | ×              | IER0F.IEN4 |        | _            |
| MTU2                                            | TGIA2    | 125             | 01F4h                       | Edge                              | 0   | 0   | ×              | IER0F.IEN5 | IPR125 | DTCER12      |
|                                                 | TGIB2    | 126             | 01F8h                       | Edge                              | 0   | 0   | ×              | IER0F.IEN6 | -      | DTCER12      |
|                                                 | TCIV2    | 127             | 01FCh                       | Edge                              | 0   | ×   | ×              | IER0F.IEN7 | IPR127 | _            |
|                                                 | TCIU2    | 128             | 0200h                       | Edge                              | 0   | ×   | ×              | IER10.IEN0 | -      | _            |
| _                                               | Reserved | 129             | 0204h                       | _                                 | ×   | ×   | ×              | _          | _      | 1-           |
| _                                               | Reserved | 130             | 0208h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | Reserved | 131             | 020Ch                       | _                                 | ×   | ×   | ×              | _          | _      | <u> </u>     |
| _                                               | Reserved | 132             | 0210h                       | _                                 | ×   | ×   | ×              | _          | _      | <u> </u>     |
| _                                               | Reserved | 133             | 0214h                       | _                                 | ×   | ×   | ×              | _          | _      | 1-           |
| _                                               | Reserved | 134             | 0218h                       | _                                 | ×   | ×   | ×              | _          | _      | 1-           |
| _                                               | Reserved | 135             | 021Ch                       | _                                 | ×   | ×   | ×              | _          | _      | 1-           |
| _                                               | Reserved | 136             | 0220h                       | _                                 | ×   | ×   | ×              | _          | _      | 1_           |
| _                                               | Reserved | 137             | 0224h                       | _                                 | ×   | ×   | ×              | _          | _      | 1_           |
| _                                               | Reserved | 138             | 0228h                       | _                                 | ×   | ×   | ×              | _          | _      | 1_           |
| MTU5                                            | TGIU5    | 139             | 022Ch                       | Edge                              | 0   | 0   | ×              | IER11.IEN3 | IPR139 | DTCER13      |
|                                                 | TGIV5    | 140             | 0230h                       | Edge                              | 0   | 0   | ×              | IER11.IEN4 | 1      | DTCER14      |
|                                                 | TGIW5    | 141             | 0234h                       | Edge                              | 0   | 0   | ×              | IER11.IEN5 | 1      | DTCER14      |
|                                                 | Reserved | 142             | 0238h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
|                                                 | Reserved | 143             | 023Ch                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | Reserved | 144             | 0240h                       | _                                 | ×   | ×   | ×              | _          | _      | <del> </del> |
| _                                               | Reserved | 145             | 0244h                       | _                                 | ×   | ×   | ×              | _          | _      | 1_           |
| _                                               | Reserved | 146             | 0248h                       | _                                 | ×   | ×   | ×              | _          | _      | _            |
| _                                               | Reserved | 147             | 024Ch                       | _                                 | ×   | ×   | ×              | _          | _      | 1_           |
| _                                               | Reserved | 148             | 0250h                       | _                                 | ×   | ×   | ×              | _          | _      | 1_           |
|                                                 | Reserved | 149             | 0254h                       | _                                 | ×   | ×   | ×              | _          | _      | 1_           |

Table 14.3 Interrupt Vector Table (5/7)

| Source of<br>Interrupt<br>Request<br>Generation | Name     | Vector<br>No.*1 | Vector<br>Address<br>Offset | Form of<br>Interrupt<br>Detection | CPU | DTC | sstb<br>Return | IER | IPR      | DTCER |
|-------------------------------------------------|----------|-----------------|-----------------------------|-----------------------------------|-----|-----|----------------|-----|----------|-------|
| _                                               | Reserved | 150             | 0258h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 151             | 025Ch                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 152             | 0260h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 153             | 0264h                       | _                                 | ×   | ×   | ×              | _   | <u> </u> | _     |
| _                                               | Reserved | 154             | 0268h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 155             | 026Ch                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 156             | 0270h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 157             | 0274h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 158             | 0278h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 159             | 027Ch                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 160             | 0280h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 161             | 0284h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
|                                                 | Reserved | 162             | 0288h                       | _                                 | ×   | ×   | ×              | _   |          | _     |
| _                                               | Reserved | 163             | 028Ch                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 164             | 0290h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 165             | 0294h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 166             | 0298h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 167             | 029Ch                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 168             | 02A0h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 169             | 02A4h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 170             | 02A8h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 171             | 02ACh                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 172             | 02B0h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 173             | 02B4h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 174             | 02B8h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 175             | 02BCh                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 176             | 02C0h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 177             | 02C4h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 178             | 02C8h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 179             | 02CCh                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 180             | 02D0h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 181             | 02D4h                       | _                                 | ×   | ×   | ×              | _   | _        |       |
|                                                 | Reserved | 182             | 02D8h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
|                                                 | Reserved | 183             | 02DCh                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 184             | 02E0h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
|                                                 | Reserved | 185             | 02E4h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 186             | 02E8h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
| _                                               | Reserved | 187             | 02ECh                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
|                                                 | Reserved | 188             | 02F0h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
|                                                 | Reserved | 189             | 02F4h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
|                                                 | Reserved | 190             | 02F8h                       | _                                 | ×   | ×   | ×              | _   | _        |       |
|                                                 | Reserved | 191             | 02FCh                       | _                                 | ×   | ×   | ×              | _   | _        | _     |
|                                                 | Reserved | 192             | 0300h                       | _                                 | ×   | ×   | ×              | _   | _        | _     |

Table 14.3 Interrupt Vector Table (6/7)

| Source of<br>Interrupt<br>Request<br>Generation | Name     | Vector<br>No.*1 | Vector<br>Address<br>Offset | Form of<br>Interrupt<br>Detection | СРИ | DTC | sstb<br>Return | IER        | IPR      | DTCER    |
|-------------------------------------------------|----------|-----------------|-----------------------------|-----------------------------------|-----|-----|----------------|------------|----------|----------|
| _                                               | Reserved | 193             | 0304h                       | _                                 | ×   | ×   | ×              | _          | <u> </u> | _        |
| _                                               | Reserved | 194             | 0308h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 195             | 030Ch                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 196             | 0310h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 197             | 0314h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 198             | 0318h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 199             | 031Ch                       | _                                 | ×   | ×   | ×              | _          | _        | -        |
| _                                               | Reserved | 200             | 0320h                       | _                                 | ×   | ×   | ×              | _          | _        | -        |
| _                                               | Reserved | 201             | 0324h                       | _                                 | ×   | ×   | ×              | _          | _        | -        |
| _                                               | Reserved | 202             | 0328h                       | _                                 | ×   | ×   | ×              | _          | _        | -        |
| _                                               | Reserved | 203             | 032Ch                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 204             | 0330h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
|                                                 | Reserved | 205             | 0334h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 206             | 0338h                       | _                                 | ×   | ×   | ×              | _          | _        | -        |
| _                                               | Reserved | 207             | 033Ch                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
|                                                 | Reserved | 208             | 0340h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 209             | 0344h                       | _                                 | ×   | ×   | ×              | _          | _        | -        |
| _                                               | Reserved | 210             | 0348h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 211             | 034Ch                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 212             | 0350h                       | _                                 | ×   | ×   | ×              | _          | _        | -        |
| _                                               | Reserved | 213             | 0354h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 214             | 0358h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 215             | 035Ch                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 216             | 0360h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 217             | 0364h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| SCI1                                            | ERI1     | 218             | 0368h                       | Level                             | 0   | ×   | ×              | IER1B.IEN2 | IPR218   | _        |
|                                                 | RXI1     | 219             | 036Ch                       | Edge                              | 0   | 0   | ×              | IER1B.IEN3 |          | DTCER219 |
|                                                 | TXI1     | 220             | 0370h                       | Edge                              | 0   | 0   | ×              | IER1B.IEN4 |          | DTCER220 |
|                                                 | TEI1     | 221             | 0374h                       | Level                             | 0   | ×   | ×              | IER1B.IEN5 |          | _        |
| SCI5                                            | ERI5     | 222             | 0378h                       | Level                             | 0   | ×   | ×              | IER1B.IEN6 | IPR222   | _        |
|                                                 | RXI5     | 223             | 037Ch                       | Edge                              | 0   | 0   | ×              | IER1B.IEN7 |          | DTCER22  |
|                                                 | TXI5     | 224             | 0380h                       | Edge                              | 0   | 0   | ×              | IER1C.IEN0 |          | DTCER224 |
|                                                 | TEI5     | 225             | 0384h                       | Level                             | 0   | ×   | ×              | IER1C.IEN1 |          | _        |
| _                                               | Reserved | 226             | 0388h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 227             | 038Ch                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 228             | 0390h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 229             | 0394h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 230             | 0398h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 231             | 039Ch                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 232             | 03A0h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 233             | 03A4h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 234             | 03A8h                       | _                                 | ×   | ×   | ×              | _          | _        | _        |
| _                                               | Reserved | 235             | 03ACh                       | _                                 | ×   | ×   | ×              | _          | İ —      | <b> </b> |

Table 14.3 Interrupt Vector Table (7/7)

| Source of<br>Interrupt<br>Request<br>Generation | Name     | Vector<br>No.*1 | Vector<br>Address<br>Offset | Form of<br>Interrupt<br>Detection | CPU | DTC | sstb<br>Return | IER        | IPR    | DTCER    |
|-------------------------------------------------|----------|-----------------|-----------------------------|-----------------------------------|-----|-----|----------------|------------|--------|----------|
| _                                               | Reserved | 236             | 03B0h                       | _                                 | ×   | ×   | ×              | _          | _      | _        |
| _                                               | Reserved | 237             | 03B4h                       | _                                 | ×   | ×   | ×              | _          | _      | _        |
| SCI12                                           | ERI12    | 238             | 03B8h                       | Level                             | 0   | ×   | ×              | IER1D.IEN6 | IPR238 | _        |
|                                                 | RXI12    | 239             | 03BCh                       | Edge                              | 0   | 0   | ×              | IER1D.IEN7 |        | DTCER239 |
|                                                 | TXI12    | 240             | 03C0h                       | Edge                              | 0   | 0   | ×              | IER1E.IEN0 | 1      | DTCER240 |
|                                                 | TEI12    | 241             | 03C4h                       | Level                             | 0   | ×   | ×              | IER1E.IEN1 | 1      | _        |
|                                                 | SCIX0    | 242             | 03C8h                       | Level                             | 0   | ×   | ×              | IER1E.IEN2 | IPR242 | _        |
|                                                 | SCIX1    | 243             | 03CCh                       | Level                             | 0   | ×   | ×              | IER1E.IEN3 | IPR243 | _        |
|                                                 | SCIX2    | 244             | 03D0h                       | Level                             | 0   | ×   | ×              | IER1E.IEN4 | IPR244 | _        |
|                                                 | SCIX3    | 245             | 03D4h                       | Level                             | 0   | ×   | ×              | IER1E.IEN5 | IPR245 | _        |
| RIIC0                                           | EEI0     | 246             | 03D8h                       | Level                             | 0   | ×   | ×              | IER1E.IEN6 | IPR246 | _        |
|                                                 | RXI0     | 247             | 03DCh                       | Edge                              | 0   | 0   | ×              | IER1E.IEN7 | IPR247 | DTCER247 |
|                                                 | TXI0     | 248             | 03E0h                       | Edge                              | 0   | 0   | ×              | IER1F.IEN0 | IPR248 | DTCER248 |
|                                                 | TEI0     | 249             | 03E4h                       | Level                             | 0   | ×   | ×              | IER1F.IEN1 | IPR249 | _        |
| _                                               | Reserved | 250             | 03E8h                       | _                                 | ×   | ×   | ×              | _          | _      | _        |
| _                                               | Reserved | 251             | 03ECh                       | _                                 | ×   | ×   | ×              | _          | _      | _        |
| _                                               | Reserved | 252             | 03F0h                       | _                                 | ×   | ×   | ×              | _          | _      | _        |
| _                                               | Reserved | 253             | 03F4h                       | _                                 | ×   | ×   | ×              | _          | _      | _        |
| _                                               | Reserved | 254             | 03F8h                       | _                                 | ×   | ×   | ×              | _          | _      | _        |
| _                                               | Reserved | 255             | 03FCh                       | _                                 | ×   | ×   | ×              | _          | _      | _        |

Note 1. An interrupt source with a smaller vector number takes precedence.

#### 14.3.2 Fast Interrupt Vector Table

The address of the entry in the interrupt vector table that corresponds to the vector number of the fast interrupt is placed in the fast interrupt vector register (FINTV) of the CPU.

#### 14.3.3 Non-maskable Interrupt Vector Table

The non-maskable interrupt vector table area is FFFF FFF8h.

### 14.4 Interrupt Operation

The interrupt controller performs the following processing.

- Detecting interrupts
- Enabling and disabling interrupts
- Selecting interrupt request destinations (CPU interrupt, DTC activation)
- Determining priority

### 14.4.1 Detecting Interrupts

Interrupt requests are detected in either of two ways: the detection of edges of the interrupt signal or the detection of a level of the interrupt signal.

Edge detection or level detection is selected for the IRQi pins (i = 0 to 7) as external interrupt requests by the setting of the IRQCRi.IRQMD[1:0] bits.

For interrupts from peripheral modules, either edge detection or level detection is determined for each interrupt source. For the correspondence between interrupt sources and methods of detection, see Table 14.3, Interrupt Vector Table.

## 14.4.1.1 Operation of Status Flags for Edge-Detected Interrupts

Figure 14.2 shows the operation of the IRn.IR flag in the case of edge detection of an interrupt from a peripheral module or on an external pin.

The IRn.IR flag is set to 1 immediately after the transition of the interrupt signal due to generation of the interrupt. If the CPU is the request destination for the interrupt, the IR flag is automatically cleared to 0 on acceptance of the interrupt. If the DTC is the request destination for the interrupt, the IRn.IR flag operation differs according to the DTC transfer settings and transfer count. For details, see Table 14.4, Operation at DTC Activation. It is not necessary to clear the IRn.IR flag by software.



Figure 14.2 IRn.IR Flag Operation for Edge Detection Interrupts

Figure 14.3 to Figure 14.5 show the interrupt signals of the interrupt controller. Note that the timings of the interrupts with interrupt vector numbers 64 to 95 are different from those of other interrupts. For the IRQ pin interrupts with interrupt vector numbers 64 to 79, "internal delay + 2 PCLK cycles" of delay is added after the IRQ pin input. For the interrupts with interrupt vector numbers 80 to 95, "2 PCLK cycles" of delay is added.

While the IRn.IR flag is 1 after an interrupt request is generated, the interrupt request that is generated again will be ignored.\*1

Figure 14.3 shows the timing for IRn.IR flag re-setting.

Note 1. When the transmission or reception interrupt of the SCI, RSPI, or RIIC is generated with the IRn.IR flag being 1, the interrupt request is retained. After the IRn.IR flag is set to 0, the IRn.IR flag is set to 1 again by the retained request. For details, refer to descriptions of the interrupts in section 23, Serial Communications Interface (SCIe, SCIf), section 24, I<sup>2</sup>C-bus Interface (RIIC), and section 25, Serial Peripheral Interface (RSPI).



Figure 14.3 Timing for IRn.IR Flag Re-Setting

If an interrupt is disabled after the IRn.IR flag is set to 1 (output of the interrupt request is disabled by the interrupt enable bit of the relevant peripheral module), the IRn.IR flag is not affected but retains its state. Figure 14.4 shows operation when the interrupt is disabled.



Figure 14.4 Relationship between IRn.IR Flag Operation and Disabling of Interrupt Request

### 14.4.1.2 Operation of Status Flags for Level-Detected Interrupts

Figure 14.5 shows the operation of the interrupt status flag (IR flag) in IRn in the case of level detection of an interrupt from a peripheral module or an external pin.

The IRn.IR flag remains set to 1 as long as the interrupt signal is asserted. To set the IRn.IR flag to 0, clear the interrupt request in the source generating the interrupt. Confirm that the interrupt request flag in the source generating the interrupt has been set to 0 and that the IRn.IR flag has been set to 0, and then complete the interrupt handling.



Figure 14.5 IRn.IR Flag Operation for Level Detection Interrupts

Figure 14.6 shows the procedure for handling level detection interrupts.



Figure 14.6 Procedure for Handling Level Detection Interrupts

## 14.4.2 Enabling and Disabling Interrupt Sources

Enabling requests from a given interrupt source requires the following settings.

- 1. In the case of interrupt requests from peripheral modules, setting the interrupt enable bit for the peripheral module to permit the output of interrupt requests from the source
- 2. Enabling of the interrupt by the IERm.IENj bit

When an interrupt request that is enabled at the corresponding source is generated, the corresponding IRn.IR flag is set to 1. Setting the IERm.IENj bit to enable an interrupt request allows the interrupt request for which the corresponding IRn.IR is 1 to be output to the interrupt request destination. Setting the IERm.IENj bit to disable an interrupt request suspends the output of the interrupt request for which the corresponding IRn.IR is 1.

The IRn.IR flag is not affected by the IERm.IENj bit.

Use the following procedure to disable interrupt requests.

- 1. Set the IERm.IENj bit to disable interrupt requests.
- 2. Set the peripheral module interrupt output enable bit to disable the output. Read the last written register and confirm that writing is completed.
- 3. Check the IRn.IR flag, and set the IRn.IR flag to 0 if necessary.\*1
- Note 1. To disable the transmission or reception interrupt of the SCI, RSPI, or RIIC from the enabled state, set the IRn.IR flag to 0 using the above procedure. For details, refer to descriptions of the interrupts in section 23, Serial Communications Interface (SCIe, SCIf), section 24, I<sup>2</sup>C-bus Interface (RIIC), and section 25, Serial Peripheral Interface (RSPI).

## 14.4.3 Selecting Interrupt Request Destinations

Possible settings for the request destination of each interrupt are fixed. That is, settings for request destination other than those listed in Table 14.3, Interrupt Vector Table, are not possible. Do not make an interrupt request destination setting that is not indicated by a O in Table 14.3.

If the DTC is selected as the destination for requests from an IRQ pin, be sure to set the IRQCRi.IRQMD[1:0] bits for that interrupt to select edge detection.

The following describes how to specify the destinations of interrupt requests.

#### (1) DTC Activation

Make the following settings for interrupt sources while the IERm.IENj bit is 0.

Set the DTC activation enable bit in the DTC activation enable register (DTCERn.DTCE) for the pertinent source to
 1.

After making the above settings, set the IERm.IENj bit to 1.

In addition, set the DTC module start bit (DTCST.DTCST) to 1. The order of making settings for interrupt sources and enabling the DTC module start bit does not matter.

For the DTC setting procedure, refer to section 16.5, DTC Setting Procedure, in section 16, Data Transfer Controller (DTCa).

#### (2) CPU Interrupt Request

If the interrupt request destination is not the DTC, the interrupt request is sent to the CPU. Set the IERm.IENj bit to 1 while not the DTC activation settings described above are in place.

Table 14.4 shows operation when the DTC is the request destination.



The DTCFR DTCF bit is cleared and

the CPU becomes the destination.

Interrupt Request Remaining Number of Operation for Interrupt Request Destination after Destination DISEL **Transfer Operations Each Request** Transfer DTC\*2 DTC DTC transfer Cleared on interrupt acceptance by the CPU → CPU interrupt = 0 DTC transfer Cleared on interrupt acceptance by The DTCER.DTCE bit is cleared and the CPU becomes the destination. → CPU interrupt ≠ 0 DTC transfer Cleared at the start of DTC data transfer after reading DTC transfer information

Cleared on interrupt acceptance by

Table 14.4 Operation at DTC Activation

DISEL for the DTC is set by the DTC.MRB.DISEL bit.

= 0

Note 1. When the IRn.IR flag is 1, an interrupt request (DTC activation request) that is generated again will be ignored.

Note 2. For chain transfer, DTC transfer continues until the last chain transfer ends. Whether a CPU interrupt is generated at the end of chain transfer, the IRn.IR flag clear timing, and the interrupt request destination after transfer are determined by the state of DISEL and the remaining transfer count at the end of chain transfer. For the chain transfer, see Table 16.3, Chain Transfer Conditions in section 16, Data Transfer Controller (DTCa).

the CPU

The request destination for an interrupt should be changed while the IERm.IENj bit is 0.

DTC transfer

→ CPU interrupt

When a source is to be changed to an interrupt request or the DTC transfer information is to be changed while a transfer is not complete (i.e. while the DTCERn.DTCE bit has not been cleared) after the settings described under (1) DTC Activation have been made, follow the procedure below.

- 1. For both the source to be withdrawn and the source that will have a new target for activation, set the IERm.IENj bit to 0.
- 2. Check the state of transfer by the DTC. If transfer is in progress, wait for its completion.
- 3. Make the settings described under (1) DTC Activation.

#### 14.4.4 Determining Priority

Interrupt priority is determined for each interrupt request destination.

The priority for each interrupt request destination is determined as follows.

#### (1) Determining Priority When the CPU is the Request Destination of the Interrupt

A source selected for the fast interrupt has the highest priority. After that, an interrupt source with a larger value of the interrupt priority level select bits (IPRn.IPR[3:0]) takes priority. If interrupts with the same priority level are generated by multiple sources, the source with the smallest vector number takes precedence.

#### (2) Determining Priority When the DTC is the Request Destination of the Interrupt

The IPRn.IPR[3:0] bits have no effect. An interrupt source with a smaller vector number takes precedence.

#### 14.4.5 Multiple Interrupts

To enable multiple interrupts of the CPU, set the PSW.I bit to 1 (interrupt enabled) in the handling routine of accepted interrupts.

The PSW.IPL[3:0] bits immediately after processing branches to the interrupt handling routine are set to the same value as the interrupt priority level of the accepted interrupt request. If an interrupt request which has an interrupt level higher than that of the PSW.IPL[3:0] bits is generated at this time, this interrupt request (for multiple interrupts) is accepted. If the interrupt priority level of the accepted interrupt request is 15 (fast interrupt or interrupt when IPR[3:0] are set to 1111b), multiple interrupts are not generated.



#### 14.4.6 Fast Interrupt

The fast interrupt is an interrupt for executing a faster interrupt response by the CPU, so only one of the interrupt sources can be assigned.

The interrupt priority level of the fast interrupt is 15 (highest) regardless of the setting of the IPRn.IPR[3:0] bits. In addition, the fast interrupt is accepted with precedence over other interrupt sources with level 15. However, when the value of the PSW.IPL[3:0] bits are 1111b (priority level 15), even the fast interrupt cannot be accepted.

To assign an interrupt source to the fast interrupt, specify the vector number of the source in the FIR.FVCT[7:0] bits, and set the FIR.FIEN bit to 1 (fast interrupt is enabled).

For details on the fast interrupt, see section 2, CPU and section 13, Exception Handling.

#### 14.4.7 Digital Filter

The digital filter function is provided for the external interrupt request IRQi pins (i = 0 to 7) and NMI pin interrupt. The digital filter samples input signals at the filter sampling clock (PCLK) and removes the pulses of which length is less than three sampling cycles.

To use the digital filter for the IRQi pin, set the sampling clock cycle (PCLK, PCLK/8, PCLK/32, or PCLK/64) with the IRQFLTC0.FCLKSELi[1:0] bits (i = 0 to 7) and set the IRQFLTE0.FLTENi bit to 1 (digital filter enabled).

To use the digital filter for the NMI pin, set the sampling clock cycle (PCLK, PCLK/8, PCLK/32, or PCLK/64) with the NMIFLTC.NFCLKSEL[1:0] bits and set the NMIFLTE.NFLTEN bit to 1 (digital filter enabled).

Figure 14.7 shows an example of digital filter operation.



Figure 14.7 Digital Filter Operation Example

Before software standby mode is entered, set the IRQFLTE0.FLTENi and NMIFLTE.NFLTEN bits to 0 (digital filter disabled). To use the digital filter again after return from software standby mode, set the IRQFLTE0.FLTENi or NMIFLTE.NFLTEN bit to 1 (digital filter enabled).

### 14.4.8 External Pin Interrupts

The procedure for using the signal on an external pin as an interrupt is as follows.

- 1. Set the IERm.IENj bit to 0 (interrupt request disabled).
- 2. Set the IRQFLTE0.FLTENi bit (i = 0 to 7) to 0 (digital filter disabled).
- 3. Set the digital filter sampling clock with the IRQFLTC0.FCLKSELi[1:0] bits.
- 4. Make or confirm the I/O port settings.
- 5. Set the method of detection for the interrupt in the IRQCRi.IRQMD[1:0] bits.
- 6. Set the corresponding IRn.IR flag to 0 (if edge detection is in use).
- 7. Set the IRQFLTE0.FLTENi bit to 1 (digital filter enabled).
- 8. If the interrupt is to be used for DTC activation, set the DTCERn.DTCE bit. (The interrupt will be a CPU interrupt if settings is not made.)
- 9. Set the IERm.IENj bit to 1 (interrupt request enabled).

#### 14.5 Non-maskable Interrupt Operation

There are six types of non-maskable interrupt: the NMI pin interrupt, oscillation stop detection interrupt, IWDT underflow/refresh error, voltage monitoring 1 interrupt, and voltage monitoring 2 interrupt. Non-maskable interrupts are only usable as interrupts for the CPU; that is, they are not capable of DTC activation. Non-maskable interrupts take precedence over all interrupts, including the fast interrupt.

Non-maskable interrupt requests are accepted regardless of the states of the I (interrupt enable) bit and IPL[3:0] (processor interrupt priority level) bits in the PSW of the CPU. The current states of the non-maskable interrupts can be checked in the non-maskable interrupt status register (NMISR).

Confirm that all bits in the NMISR have returned to 0 in the non-maskable interrupt handler.

Non-maskable interrupts are disabled by default. If a system is to use non-maskable interrupts, the following procedure must be followed at the beginning of program processing.

Non-maskable interrupt usage procedure:

- 1. Set the stack pointer (SP).
- 2. To use the NMI pin, set the NMIFLTE.NFLTEN bit to 0 (digital filter disabled).
- 3. To use the NMI pin, set the digital filter sampling clock with the NMIFLTC.NFCLKSEL[1:0] bits.
- 4. To use the NMI pin, set the NMI pin interrupt detection method with the NMICR.NMIMD bit.
- 5. To use the NMI pin, write 1 to the NMICLR.NMICLR bit to set the NMISR.NMIST flag to 0.
- 6. To use the NMI pin, set the NMIFLTE.NFLTEN bit to 1 (digital filter enabled).
- 7. Enable the non-maskable interrupt by writing 1 to the corresponding bit in the non-maskable interrupt enable register (NMIER).

After 1 is written to the NMIER register, subsequent write access to the NMIEN bit in NMIER is ignored. The NMI interrupt cannot be disabled. It can be disabled only by a reset.

For the flow of non-maskable interrupt handling, refer to section 13, Exception Handling.

Writing 1 to the NMICLR.NMICLR bit sets the NMI status flag (NMISR.NMIST) to 0.

Writing 1 to the NMICLR.OSTCLR bit sets the oscillation stop detection interrupt status flag (NMISR.OSTST) to 0.

Writing 1 to the NMICLR.IWDTCLR bit sets the IWDT underflow/refresh error status flag (NMISR.IWDTST) to 0.

Writing 1 to the NMICLR.LVD1CLR bit sets the voltage monitoring 1 interrupt status flag (NMISR.LVD1ST) to 0.

Writing 1 to the NMICLR.LVD2CLR bit sets the voltage monitoring 2 interrupt status flag (NMISR.LVD2ST) to 0.

#### 14.6 Return from Power-Down States

The interrupt sources that can be used to return operation from sleep mode, deep sleep mode, or software standby mode are listed in Table 14.3, Interrupt Vector Table.

For details, refer to section 11, Low Power Consumption. The following describes how to use an interrupt to return operation from each low power consumption mode.

#### 14.6.1 Return from Sleep Mode or Deep Sleep Mode

If the interrupt controller is to return operation from sleep mode in response to an interrupt or non-maskable interrupt, make the following settings for the interrupt.

- Interrupts
- 1. Select the CPU as the interrupt request destination.
- 2. Use the IERm.IENj bit to enable the given interrupt request.
- 3. Set a priority level higher than that set in the CPU.PSW.IPL[3:0] bits.
- Non-maskable interrupts

Use the NMIER register to enable the given interrupt request.

### 14.6.2 Return from Software Standby Mode

The interrupt controller can return operation from a non-maskable interrupt or an interrupt that enables the return from the software standby mode.

The conditions for the return are listed below.

- Interrupts
- 1. Select the interrupt source that enables the return from the software standby mode.
- 2. Select the CPU as the interrupt request destination.
- 3. Use the IERm.IENj bit to enable the given interrupt request.
- 4. Set a priority level higher than that set in the CPU.PSW.IPL[3:0] bits.
  (For the interrupt source specified as a fast interrupt, as well as setting the fast interrupt set register (FIR), the interrupt priority level (IPRn) should be set above the level set by CPU.PSW.IPL.)

Interrupt requests through the IRQ pins that do not satisfy the above conditions are not detected while the clock is stopped in software standby mode.

Non-maskable interrupts

Use the NMIER register to enable the given interrupt request.

- Procedure to make a transition to/from software standby mode
- 1. Before software standby mode is entered, disable the digital filter for the interrupt source as a return target (IRQFLTE0.FLTENi = 0, NMIFLTE.NFLTEN = 0).
- 2. To use the digital filter again after return from software standby mode, enable the digital filter (IRQFLTE0.FLTENi = 1, NMIFLTE.NFLTEN = 1).

#### 14.7 Usage Note

#### 14.7.1 Note on WAIT Instruction Used with Non-Maskable Interrupt

Before executing the WAIT instruction, check to see that all the status flags in NMISR are 0.



RX110 Group 15. Buses

## 15. Buses

### 15.1 Overview

Table 15.1 lists the bus specifications, Figure 15.1 shows the bus configuration, and Table 15.2 lists the addresses assigned to each bus.

Table 15.1 Bus Specifications

| Bus Type                        |                              | Description                                                                                                                                                                         |  |
|---------------------------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CPU bus                         | Instruction bus              | <ul> <li>Connected to the CPU for instructions</li> <li>Connected to on-chip memory (RAM, ROM)</li> <li>Operates in synchronization with the system clock (ICLK)</li> </ul>         |  |
|                                 | Operand bus                  | <ul> <li>Connected to the CPU (for operands)</li> <li>Connected to on-chip memory (RAM, ROM)</li> <li>Operates in synchronization with the system clock (ICLK)</li> </ul>           |  |
| Memory bus                      | Memory bus 1                 | Connected to RAM                                                                                                                                                                    |  |
|                                 | Memory bus 2                 | Connected to ROM                                                                                                                                                                    |  |
| Internal main buses             | Internal main bus 1          | Connected to the CPU     Operates in synchronization with the system clock (ICLK)                                                                                                   |  |
|                                 | Internal main bus 2          | <ul> <li>Connected to the DTC</li> <li>Connected to on-chip memory (RAM, ROM)</li> <li>Operates in synchronization with the system clock (ICLK)</li> </ul>                          |  |
| Internal<br>peripheral<br>buses | Internal peripheral<br>bus 1 | <ul> <li>Connected to peripheral modules (DTC, interrupt controller, and bus error monitoring section)</li> <li>Operates in synchronization with the system clock (ICLK)</li> </ul> |  |
|                                 | Internal peripheral bus 2    | <ul> <li>Connected to peripheral modules</li> <li>Operates in synchronization with the peripheral module clock (PCLKB)</li> </ul>                                                   |  |
|                                 | Internal peripheral<br>bus 6 | Connected to ROM (P/E)     Operates in synchronization with the FlashIF clock (FCLK)                                                                                                |  |

P/E: Programming/Erasure

RX110 Group 15. Buses



Figure 15.1 Bus Configuration

Table 15.2 Addresses Assigned for Each Bus

| Address                  | Bus                       | Area                             |
|--------------------------|---------------------------|----------------------------------|
| 0000 0000h to 0000 FFFFh | Memory bus 1              | RAM                              |
| 0008 0000h to 0008 7FFFh | Internal peripheral bus 1 | Peripheral I/O registers         |
| 0008 8000h to 0009 FFFFh | Internal peripheral bus 2 |                                  |
| 0010 0000h to 00FF FFFFh | Internal peripheral bus 6 | ROM<br>(for programming/erasure) |
| 8000 0000h to FEFF FFFFh | Memory bus 2              | ROM                              |
| FF00 0000h to FFFF FFFFh |                           | (for reading only)               |

RX110 Group 15. Buses

#### 15.2 Description of Buses

#### 15.2.1 CPU Buses

The CPU buses consist of the instruction and operand buses, which are connected to internal main bus 1. As the names suggest, the instruction bus is used to fetch instructions for the CPU, while the operand bus is used for operand access. Connection of the instruction and operand buses to RAM and ROM provides the CPU with direct access to these areas, i.e. access is not via internal main bus 1. However, only reading is possible in direct access to ROM by the CPU; programming and erasure are handled via an internal peripheral bus.

Bus requests for instruction fetching and operand access are arbitrated through internal main bus 1. The order of priority is operand access then instruction fetching.

If instruction fetching and operand access are requested for different buses (memory bus 1, memory bus 2, and internal main bus 1), the bus-access operations can proceed simultaneously. For example, parallel access to ROM and RAM is possible.

## 15.2.2 Memory Buses

The memory buses consist of memory bus 1 and memory bus 2. RAM is connected to memory bus 1 and ROM is connected to memory bus 2. Requests for bus mastership from the CPU buses (instruction fetching and operand) and internal main bus 2 are arbitrated through memory buses 1 and 2.

The priority order of CPU bus and internal main bus 2 can be set using the memory bus 1 (RAM) priority control bits (BPRA[1:0]) and memory bus 2 (ROM) priority control bits (BPRO[1:0]) in the bus priority control register (BUSPRI) for the corresponding memory buses. When the priority order is fixed, internal main bus 2 has priority over the CPU bus (operand over instruction fetching). When the priority order is toggled, the bus for which a request has been accepted has lower priority.

#### 15.2.3 Internal Main Buses

The internal main buses consist of a bus for use by the CPU (internal main bus 1) and a bus for use by the other bus-master modules, i.e. the DTC (internal main bus 2).

Bus requests for instruction fetching and operand access are arbitrated through internal main bus 1. The order of priority is operand access then instruction fetching.

Requests for bus mastership from the DTC is arbitrated by internal main bus 2. The order of priority is as shown in Table 15.3.

If the CPU and another bus master are requesting access to different buses (on-chip memory, internal peripheral buses 1, 2, and 6), the respective bus-access operations can proceed simultaneously.

However, when the CPU executes the XCHG instruction, requests for bus access from masters other than the CPU are not accepted until data transfer for the XCHG instruction is completed regardless of the bus priority control register (BUSPRI) setting. Furthermore, requests for bus access from masters other than the DTC are not accepted during reading and writing-back of transfer control information for the DTC.

Table 15.3 Order of Priority for Bus Masters

| Priority | Bus Master |
|----------|------------|
| High     | DTC        |
| T<br>Low | CPU        |

### 15.2.4 Internal Peripheral Buses

Connection of peripheral modules to the internal peripheral buses is as described in Table 15.4.

Table 15.4 Connection of Peripheral Modules to the Internal Peripheral Buses

| Type of Bus               | Peripheral Modules                                                         |
|---------------------------|----------------------------------------------------------------------------|
| Internal peripheral bus 1 | DTC, interrupt controller, and bus error monitoring section                |
| Internal peripheral bus 2 | Peripheral modules other than those connected to internal peripheral bus 1 |
| Internal peripheral bus 6 | ROM (P/E)                                                                  |

Requests for bus mastership from the CPU (internal main bus 1) and other bus masters (internal main bus 2) are arbitrated through internal peripheral buses 1, 2, and 6.

The priority order of the two internal main buses can be set using the bus priority control register (BUSPRI). The priority order can be set with the internal peripheral bus 1 priority control bits (BUSPRI.BPIB[1:0]), internal peripheral bus 2 priority control bits (BUSPRI.BPGB[1:0]), and internal peripheral bus 6 priority control bits (BUSPRI.BPFB[1:0]) for the corresponding internal peripheral buses. When the priority order is fixed, internal main bus 2 has priority over internal main bus 1. When the priority order is toggled, a bus has a lower priority when the request of that bus is accepted.

The order of accepting requests may change depending on the BUSPRI setting (see Figure 15.2).



Figure 15.2 Priority Order Between Internal Peripheral Bus Accesses

### 15.2.5 Write Buffer Function (Internal Peripheral Bus)

The internal peripheral bus has the write buffer function, which allows the next round of bus access to start, before the current write access is completed, in write access. However, if the following round of bus access is from the same bus master but to the different internal peripheral bus, it is suspended until the bus operations already in progress are completed. When read access to the internal memory is scheduled after the write access to the internal peripheral bus from the CPU, the following round of bus access can be started before the current bus operation is completed and thus the order of accesses may be changed (see Figure 15.3).



Figure 15.3 Write Buffer Function

## 15.2.6 Parallel Operation

Parallel operation is possible when different bus-master modules are requesting access to different slave modules. For example, if the CPU is fetching an instruction from ROM and an operand from RAM, the DTC is able to handle transfer between a peripheral bus and peripheral bus at the same time.

An example of parallel operations is shown in Figure 15.4. In this example, the CPU is able to employ the instruction and operand buses for simultaneous access to ROM and RAM, respectively. Furthermore, the DTC simultaneously employs internal main bus 2 for access to a peripheral bus during access to RAM and ROM by the CPU.



Figure 15.4 Example of Parallel Operations

#### 15.2.7 Restrictions

#### (1) Prohibition of Access that Spans Multiple Areas of Address Space

Single access that spans two areas of the address space is prohibited, and operation of such an access is not guaranteed. Ensure that a single word or longword access does not span across two areas by crossing address space area boundaries.

#### (2) Restrictions on RMPA and String-Manipulation Instructions

(a) The allocation of data to be handled by RMPA or string-manipulation instructions to I/O registers is prohibited, and operation is not guaranteed if this restriction is not observed.

### 15.3 Register Descriptions

# 15.3.1 Bus Error Status Clear Register (BERCLR)

Address(es): 0008 1300h



| Bit      | Symbol | Bit Name     | Description                                            | R/W   |
|----------|--------|--------------|--------------------------------------------------------|-------|
| b0       | STSCLR | Status Clear | 0: Invalid<br>1: Bus error status register cleared     | (W)*1 |
| b7 to b1 | _      | Reserved     | These bits are read as 0. The write value should be 0. | R/W   |

Note 1. Only writing 1 is effective; i.e. writing 0 has no effect.

### STSCLR Bit (Status Clear)

Writing 1 to this bit clears the bus error status registers 1 and 2 (BERSR1 and BERSR2).

Writing 0 has no effect. It is read as 0.

### 15.3.2 Bus Error Monitoring Enable Register (BEREN)

Address(es): 0008 1304h



| Bit      | Symbol | Bit Name                                   | Description                                                                                                                | R/W |
|----------|--------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | IGAEN  | Illegal Address Access Detection<br>Enable | <ul><li>0: Illegal address access detection is disabled.</li><li>1: Illegal address access detection is enabled.</li></ul> | R/W |
| b1       | TOEN   | Timeout Detection Enable*1, *2             | Bus timeout detection is disabled.     Bus timeout detection is enabled.                                                   | R/W |
| b7 to b2 | _      | Reserved                                   | These bits are read as 0. The write value should be 0.                                                                     | R/W |

Note 1. When detection is disabled (the TOEN bit is cleared to 0), bus access can cause the bus to freeze.

Note 2. Do not set the TOEN bit to 0 (bus timeout detection disabled) while timeout errors are being detected.

# 15.3.3 Bus Error Status Register 1 (BERSR1)

Address(es): 0008 1308h



| Bit      | Symbol   | Bit Name               | Description                                                                                                                                                 | R/W |
|----------|----------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | IA       | Illegal Address Access | Illegal address access not made     Illegal address access made                                                                                             | R   |
| b1       | TO       | Timeout                | 0: Timeout not generated 1: Timeout generated                                                                                                               | R   |
| b3, b2   | _        | Reserved               | These bits are read as 0. Writing to these bits has no effect.                                                                                              | R   |
| b6 to b4 | MST[2:0] | Bus Master Code        | b6 b4 0 0 0: CPU 0 0 1: Reserved 0 1 0: Reserved 0 1 1: DTC 1 0 0: Reserved 1 0 1: Reserved 1 1 0: Reserved 1 1 0: Reserved 1 1 0: Reserved 1 1 1: Reserved | R   |
| b7       | _        | Reserved               | This bit is read as 0. Writing to this bit has no effect.                                                                                                   | R   |

### MST[2:0] Bits (Bus Master Code)

These bits indicate the bus master that accessed a bus when a bus error occurred.

# 15.3.4 Bus Error Status Register 2 (BERSR2)

Address(es): 0008 130Ah



| Bit       | Symbol     | Bit Name                        | Description                                                                                           | R/W |
|-----------|------------|---------------------------------|-------------------------------------------------------------------------------------------------------|-----|
| b2 to b0  | _          | Reserved                        | These bits are read as 0. Writing to these bits has no effect.                                        | R   |
| b15 to b3 | ADDR[12:0] | Bus Error<br>Occurrence Address | The upper 13 bits of an address that was accessed when a bus error occurred (in units of 512 Kbytes). | R   |

### 15.3.5 Bus Priority Control Register (BUSPRI)

Address(es): 0008 1310h



| Bit        | Symbol    | Bit Name                                      | Description                                                                                                                                                                               | R/W         |
|------------|-----------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| b1, b0     | BPRA[1:0] | Memory Bus 1 (RAM) Priority<br>Control        | b1 b0 0 0: The order of priority is fixed. 0 1: The order of priority is toggled. 1 0: Setting prohibited 1 1: Setting prohibited                                                         | R/(W)<br>*1 |
| b3, b2     | BPRO[1:0] | Memory Bus 2 (ROM) Priority<br>Control        | <ul> <li>b3 b2</li> <li>0 0: The order of priority is fixed.</li> <li>0 1: The order of priority is toggled.</li> <li>1 0: Setting prohibited</li> <li>1 1: Setting prohibited</li> </ul> | R/(W)<br>*1 |
| b5, b4     | BPIB[1:0] | Internal Peripheral Bus 1 Priority<br>Control | <ul> <li>b5 b4</li> <li>0 0: The order of priority is fixed.</li> <li>0 1: The order of priority is toggled.</li> <li>1 0: Setting prohibited</li> <li>1 1: Setting prohibited</li> </ul> | R/(W)<br>*1 |
| b7, b6     | BPGB[1:0] | Internal Peripheral Bus 2 Priority<br>Control | b7 b6 0 0: The order of priority is fixed. 0 1: The order of priority is toggled. 1 0: Setting prohibited 1 1: Setting prohibited                                                         | R/(W)<br>*1 |
| b9, b8     | _         | Reserved                                      | These bits are read as 0. The write value should be 0.                                                                                                                                    | R/W         |
| b11, b10   | BPFB[1:0] | Internal Peripheral Bus 6 Priority<br>Control | bil bil bil 0 0 0: The order of priority is fixed. 0 1: The order of priority is toggled. 1 0: Setting prohibited 1 1: Setting prohibited                                                 | R/(W)<br>*1 |
| b15 to b12 | _         | Reserved                                      | These bits are read as 0. The write value should be 0.                                                                                                                                    | R/W         |

Note 1. These bits can be written to only once while the DTC is stopped. When they are written to more than one time, the operation is not guaranteed.

#### BPRA[1:0] Bits (Memory Bus 1 (RAM) Priority Control)

These bits specify the priority order for memory bus 1 (RAM).

When the priority order is fixed, internal main bus 2 has priority over the CPU bus.

When the priority order is toggled, a bus has a lower priority when the request of that bus is accepted.

#### BPRO[1:0] Bits (Memory Bus 2 (ROM) Priority Control)

These bits specify the priority order for memory bus 2 (ROM).

When the priority order is fixed, internal main bus 2 has priority over the CPU bus.

When the priority order is toggled, a bus has a lower priority when the request of that bus is accepted.

#### **BPIB[1:0] Bits (Internal Peripheral Bus 1 Priority Control)**

These bits specify the priority order for internal peripheral bus 1.

When the priority order is fixed, internal main bus 2 has priority over internal main bus 1.

When the priority order is toggled, a bus has a lower priority when the request of that bus is accepted.

### **BPGB[1:0] Bits (Internal Peripheral Bus 2 Priority Control)**

These bits specify the priority order for internal peripheral bus 2.

When the priority order is fixed, internal main bus 2 has priority over internal main bus 1.

When the priority order is toggled, a bus has a lower priority when the request of that bus is accepted.

### **BPFB[1:0] Bits (Internal Peripheral Bus 6 Priority Control)**

These bits specify the priority order for internal peripheral bus 6.

When the priority order is fixed, internal main bus 2 has priority over internal main bus 1.

When the priority order is toggled, a bus has a lower priority when the request of that bus is accepted.



### 15.4 Bus Error Monitoring Section

The bus error monitoring section monitors the individual areas for bus errors, and when a bus error occurs, the error is indicated to the bus master.

# 15.4.1 Type of Bus Error

There is a illegal address access bus error.

Illegal address access is the detection of access to an illegal area.

### 15.4.1.1 Illegal Address Access

When the illegal address access detection enable bit (IGAEN) in the bus error monitoring enable register (BEREN) is set to 1, access to an illegal address area leads to illegal address access errors.

The address ranges where access will lead to illegal address access errors are listed in Table 15.5.

#### 15.4.1.2 Timeout

When the timeout detection enable bit in the bus error monitoring enable register is enabled (BEREN.TOEN = 1), bus access that is not completed within 768 cycles leads to a timeout error.

- Internal peripheral buses (2): Bus access is not completed within 768 peripheral module clock (PCLKB) cycles from the start of the access.
  - If a timeout error occurs, accesses from the bus master are not accepted for 256 PCLKB cycles.
- Internal peripheral bus (6): Bus access is not completed within 768 FlashIF clock (FCLK) cycles from the start of the access.

If a timeout error occurs, accesses from the bus master are not accepted for 256 FCLK cycles.

# 15.4.2 Operations When a Bus Error Occurs

When a bus error occurs, the error is indicated to the CPU. Operation is not guaranteed when a bus error occurs.

Bus error indication to the CPU
 An interrupt is generated. The ICU.IERn register can specify whether to generate an interrupt in the case of a bus error.

# 15.4.3 Conditions Leading to Bus Errors

Table 15.5 lists the type of bus errors for each area in the respective address space.

If an illegal address access error is detected when no bus error has occurred (bus error status register n (BERSRn; n = 1, 2) is cleared), the detected error is reflected in the BERSRn register. Once a bus error occurs, no subsequent bus errors are reflected in the register unless the register is cleared.

If bus errors are simultaneously caused by two or more bus masters, error information of only one bus master is reflected. Once a bus error occurs, the status is retained until the BERSRn register is cleared.

Table 15.5 Type of Bus Errors

|                          |                           | Type of Error          |         |
|--------------------------|---------------------------|------------------------|---------|
| Address                  | Type of Area              | Illegal Address Access | Timeout |
| 0000 0000h to 0007 FFFFh | Memory bus 1              | _                      | _       |
| 0008 0000h to 0008 7FFFh | Internal peripheral bus 1 | _                      | _       |
| 0008 8000h to 0009 FFFFh | Internal peripheral bus 2 | Δ                      | _       |
| 000C 0000h to 000E FFFFh | Reserved area             | 0                      | _       |
| 0010 0000h to 00FF FFFFh | Internal peripheral bus 6 | Δ                      | _       |
| 0100 0000h to 07FF FFFFh | Reserved area             | 0                      | _       |
| 0800 0000h to 0FFF FFFFh | Reserved area             | _                      | _       |
| 1000 0000h to 7FFF FFFFh | Reserved area             | 0                      | _       |
| 8000 0000h to FFFF FFFFh | Memory bus 2              | _                      | _       |

A bus error does not result.

Note: The capacity of the RAM, and ROM differs depending on the product. For details, refer to section 30, RAM, and section 31, Flash Memory.

Δ: A bus error may or may not result.

o: A bus error results.

# 16. Data Transfer Controller (DTCa)

This MCU incorporates a data transfer controller (DTC).

The DTC is activated by an interrupt request to perform data transfers.

### 16.1 Overview

Table 16.1 lists the specifications of the DTC, and Figure 16.1 shows a block diagram of the DTC.

Table 16.1 DTC Specifications

| Item                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transfer modes                 | <ul> <li>Normal transfer mode     A single activation leads to a single data transfer.</li> <li>Repeat transfer mode     A single activation leads to a single data transfer.     The transfer address is returned to the transfer start address after the number of data transfers corresponding to "repeat size".     The maximum number of repeat transfers is 256, and the maximum data transfer size is 256 × 32 bits, 1024 bytes.</li> <li>Block transfer mode     A single activation leads to the transfer of a single block.     The maximum block size is 256 × 32 bits = 1024 bytes.</li> </ul> |
| Transfer channel               | <ul> <li>Channel transfer corresponding to the interrupt source is possible (transferred by the DTC activation request from the ICU).</li> <li>Multiple data can be transferred on a single activation source (chain transfer).</li> <li>Either "executed when the counter is 0" or "always executed" can be selected for chain transfer.</li> </ul>                                                                                                                                                                                                                                                       |
| Transfer space                 | <ul> <li>In short-address mode: 16 Mbytes (Areas from 0000 0000h to 007F FFFFh and FF80 0000h to FFFF FFFFh except reserved areas)</li> <li>In full-address mode: 4 Gbytes (Area from 0000 0000h to FFFF FFFFh except reserved areas)</li> </ul>                                                                                                                                                                                                                                                                                                                                                           |
| Data transfer units            | <ul> <li>Single data: 1 byte (8 bits), 1 word (16 bits), 1 longword (32 bits)</li> <li>Single block size: 1 to 256 data</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| CPU interrupt source           | <ul> <li>An interrupt request can be generated to the CPU on a DTC activation interrupt.</li> <li>An interrupt request can be generated to the CPU after a single data transfer.</li> <li>An interrupt request can be generated to the CPU after data transfer of specified volume.</li> </ul>                                                                                                                                                                                                                                                                                                             |
| Read skip                      | Transfer information read skip can be executed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Write-back skip                | When "fixed" is selected for transfer source address or transfer destination address, write-back skip is executed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Low power consumption function | Module stop state can be set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |



Figure 16.1 DTC Block Diagram

## 16.2 Register Descriptions

Registers MRA, MRB, SAR, DAR, CRA, and CRB are DTC internal registers, which cannot be directly accessed from the CPU. Values to be set in these DTC internal registers are placed in the RAM area as transfer information. When an activation request is generated, the DTC reads the transfer information from the RAM area and set them in the internal registers. After the data transfer ends, the internal register contents are written back to the RAM area as transfer information.

### 16.2.1 DTC Mode Register A (MRA)

Address(es): (inaccessible directly from the CPU)



x: Undefined

| Bit    | Symbol  | Bit Name                                   | Description                                                                                                          | R/W |
|--------|---------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-----|
| b1, b0 | _       | Reserved                                   | These bits are read as undefined. The write value should be 0.                                                       | _   |
| b3, b2 | SM[1:0] | Transfer Source Address Addressing<br>Mode | b3 b2 0 0: Address in the SAR register is fixed.                                                                     | _   |
| b5, b4 | SZ[1:0] | DTC Data Transfer Size                     | b5 b4 0 0: Byte (8-bit) transfer 0 1: Word (16-bit) transfer 1 0: Longword (32-bit) transfer 1 1: Setting prohibited | _   |
| b7, b6 | MD[1:0] | DTC Transfer Mode Select                   | b7 b6 0 0: Normal transfer mode 0 1: Repeat transfer mode 1 0: Block transfer mode 1 1: Setting prohibited           | _   |

MRA register cannot be accessed directly from the CPU.

### 16.2.2 DTC Mode Register B (MRB)

Address(es): (inaccessible directly from the CPU)



x: Undefined

| Bit    | Symbol  | Bit Name                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R/W |
|--------|---------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1, b0 | _       | Reserved                                        | These bits are read as undefined. The write value should be 0.                                                                                                                                                                                                                                                                                                                                                                                                                                              | _   |
| b3, b2 | DM[1:0] | Transfer Destination Address<br>Addressing Mode | <ul> <li>b3 b2</li> <li>0 0: Address in the DAR register is fixed. (Write-back to DAR is skipped.)</li> <li>0 1: Address in the DAR register is fixed. (Write-back to DAR is skipped.)</li> <li>1 0: DAR value is incremented after data transfer. (+1 when MRA.SZ[1:0] bits = 00b, +2 when SZ[1:0] bits = 01b, +4 when SZ[1:0] bits = 10b)</li> <li>1 1: DAR value is decremented after data transfer. (-1 when SZ[1:0] bits = 00b, -2 when SZ[1:0] bits = 01b, -4 when MRA.SZ[1:0] bits = 10b)</li> </ul> | _   |
| b4     | DTS     | DTC Transfer Mode Select                        | <ul><li>0: Transfer destination side is repeat area or block area.</li><li>1: Transfer source side is repeat area or block area.</li></ul>                                                                                                                                                                                                                                                                                                                                                                  | _   |
| b5     | DISEL   | DTC Interrupt Select                            | <ul><li>0: An interrupt request to the CPU is generated when specified data transfer is completed.</li><li>1: An interrupt request to the CPU is generated each time DTC data transfer is performed.</li></ul>                                                                                                                                                                                                                                                                                              | _   |
| b6     | CHNS    | DTC Chain Transfer Select                       | O: Chain transfer is performed continuously.  1: Chain transfer is performed only when the transfer counter is changed from 1 to 0 or 1 to CRAH.                                                                                                                                                                                                                                                                                                                                                            | _   |
| b7     | CHNE    | DTC Chain Transfer Enable                       | Chain transfer is disabled.     Chain transfer is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                  | _   |

MRB register cannot be accessed directly from the CPU.

#### **DTS Bit (DTC Transfer Mode Select)**

The DTS bit specifies the side (transfer source or destination) to be a repeat area or block area in repeat transfer mode or block transfer mode.

#### **CHNS Bit (DTC Chain Transfer Select)**

The CHNS bit selects the chain transfer condition.

When the CHNE bit is 0, setting of the CHNS bit is ignored. For details on the conditions to select the chain transfer, refer to Table 16.3, Chain Transfer Conditions.

When the next transfer is chain transfer, completion of the specified number of transfers is not determined, the activation source flag is not cleared, and an interrupt request to the CPU is not generated.

### **CHNE Bit (DTC Chain Transfer Enable)**

The CHNE bit enables or disables chain transfer.

The chain transfer condition is selected by the CHNS bit.

For details of chain transfer, refer to section 16.4.6, Chain Transfer.



### 16.2.3 DTC Transfer Source Register (SAR)

Address(es): (inaccessible directly from the CPU)



SAR register is used to set the transfer source start address.

In full-address mode, 32 bits are valid.

In short-address mode, lower 24 bits are valid and upper 8 bits (b31 to b24) are ignored. The address of this register is extended by the value specified by b23.

SAR register cannot be accessed directly from the CPU.

# 16.2.4 DTC Transfer Destination Register (DAR)

Address(es): (inaccessible directly from the CPU)



DAR register is used to set the transfer destination start address.

In full-address mode, 32 bits are valid.

In short-address mode, lower 24 bits are valid and upper 8 bits (b31 to b24) are ignored. The address of this register is extended by the value specified by b23.

DAR register cannot be accessed directly from the CPU.

### 16.2.5 DTC Transfer Count Register A (CRA)

Address(es): (inaccessible directly from the CPU)

#### · Normal transfer mode



• Repeat transfer mode/block transfer mode



x: Undefined

| Symbol | Register Name                     | Description         | R/W |
|--------|-----------------------------------|---------------------|-----|
| CRAL   | Transfer Counter A Lower Register | Set transfer count. | _   |
| CRAH   | Transfer Counter A Upper Register |                     |     |

Note: The function depends on transfer mode.

Note: Set CRAH and CRAL to the same value in repeat transfer mode and block transfer mode.

CRA register cannot be accessed directly from the CPU.

#### (1) Normal transfer mode (MRA.MD[1:0] bits = 00b)

CRA register functions as a 16-bit transfer counter in normal transfer mode.

The transfer count is 1, 65535, and 65536 when the set value is 0001h, FFFFh, and 0000h, respectively.

The CRA value is decremented (-1) at each data transfer.

#### (2) Repeat transfer mode (MRA.MD[1:0] bits = 01b)

The CRAH register retains the transfer count and the CRAL register functions as an 8-bit transfer counter.

The transfer count is 1, 255, and 256 when the set value is 01h, FFh, and 00h, respectively.

The CRAL value is decremented (-1) at each data transfer. When it reaches 00h, the CRAH value is transferred to CRAL.

### (3) Block transfer mode (MRA.MD[1:0] bits = 10b)

The CRAH register retains the block size and the CRAL register functions as an 8-bit block size counter.

The transfer count is 1, 255, and 256 when the set value is 01h, FFh, and 00h, respectively.

The CRAL value is decremented (-1) at each data transfer. When it reaches 00h, the CRAH value is transferred to CRAL.

### 16.2.6 DTC Transfer Count Register B (CRB)

Address(es): (inaccessible directly from the CPU)



CRB register is used to set the block transfer count for block transfer mode.

The transfer count is 1, 65535, and 65536 when the set value is 0001h, FFFFh, and 0000h, respectively.

The CRB value is decremented (-1) when the final data of a single block size is transferred.

When normal transfer mode or repeat transfer mode is selected, this register is not used and the set value is ignored. CRB register cannot be accessed directly from the CPU.

### 16.2.7 DTC Control Register (DTCCR)

Address(es): DTC.DTCCR 0008 2400h



| Bit      | Symbol | Bit Name                                     | Description                                                                                                     | R/W |
|----------|--------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-----|
| b2 to b0 | _      | Reserved                                     | These bits are read as 0. The write value should be 0.                                                          | R/W |
| b3       | _      | Reserved                                     | This bit is read as 1. The write value should be 1.                                                             | R/W |
| b4       | RRS    | DTC Transfer Information<br>Read Skip Enable | 0: Transfer information read is not skipped. 1: Transfer information read is skipped when vector numbers match. | R/W |
| b7 to b5 | _      | Reserved                                     | These bits are read as 0. The write value should be 0.                                                          | R/W |

#### RRS Bit (DTC Transfer Information Read Skip Enable)

The DTC vector number is compared with the vector number in the previous activation process.

When these vector numbers match and the RRS bit is set to 1, DTC data transfer is performed without reading the transferred information. However, when the previous transfer was chain transfer, the transferred information is read regardless of the value of the RRS bit.

Furthermore, when the transfer counter (CRA register) became 0 during the previous normal transfer and when the transfer counter (CRB register) became 0 during the previous block transfer, the transferred information is read regardless of the RRS bit value.

### 16.2.8 DTC Vector Base Register (DTCVBR)

Address(es): DTC.DTCVBR 0008 2404h



DTCVBR register is used to set the base address for calculating the DTC vector table address. Writing to the upper 4 bits (b31 to b28) is ignored, and the address of this register is extended by the value specified by b27. The lower 10 bits are reserved and the values are fixed to 0. Write 0 to the lower 10 bits if necessary.

It can be set in the range of 0000 0000h to 07FF FC00h and F800 0000h to FFFF FC00h in 1-Kbyte units.

### 16.2.9 DTC Address Mode Register (DTCADMOD)

Address(es): DTC.DTCADMOD 0008 2408h



| Bit      | Symbol | Bit Name               | Description                                            | R/W |
|----------|--------|------------------------|--------------------------------------------------------|-----|
| b0       | SHORT  | Short-Address Mode Set | 0: Full-address mode<br>1: Short-address mode          | R/W |
| b7 to b1 | _      | Reserved               | These bits are read as 0. The write value should be 0. | R/W |

DTCADMOD register is used to specify the area accessible by the DTC.

#### **SHORT Bit (Short-Address Mode Set)**

Full-address mode allows the DTC to access to a 4-Gbyte space (0000 0000h to FFFF FFFFh). Short-address mode allows the DTC to access to a 16-Mbyte space (0000 0000h to 007F FFFFh and FF80 0000h to FFFF FFFFh).

# 16.2.10 DTC Module Start Register (DTCST)

Address(es): DTC.DTCST 0008 240Ch



| Bit      | Symbol | Bit Name         | Description                                            | R/W |
|----------|--------|------------------|--------------------------------------------------------|-----|
| b0       | DTCST  | DTC Module Start | 0: DTC module stop 1: DTC module start                 | R/W |
| b7 to b1 | _      | Reserved         | These bits are read as 0. The write value should be 0. | R/W |

### **DTCST Bit (DTC Module Start)**

Set the DTCST bit to 1 to enable the DTC to accept transfer requests. When this bit is set to 0, transfer requests are no longer accepted.

If this bit is set to 0 during data transfer, the accepted transfer request is active until the processing is completed. Set the DTCST bit to 0 before making a transition to the module stop state, deep sleep mode, or software standby mode. For details on transitions to the module stop state, deep sleep mode, and software standby mode, refer to Section 16.8, Low Power Consumption Function, and section 11, Low Power Consumption.

### 16.2.11 DTC Status Register (DTCSTS)

Address(es): DTC.DTCSTS 0008 240Eh



| Bit                                                        | Symbol | Bit Name                                   | Description                                                                                                                                                                                 | R/W |  |  |
|------------------------------------------------------------|--------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|
| b7 to b0 VECN[7:0] DTC-Activating Vector Number Monitoring |        | DTC-Activating Vector<br>Number Monitoring | These bits indicate the vector number for the activation source when DTC transfer is in progress.  The value is only valid if DTC transfer is in progress (the value of the ACT flag is 1). |     |  |  |
| b14 to b8                                                  | _      | Reserved                                   | These bits are read as 0. Writing to these bits has no effect.                                                                                                                              | R   |  |  |
| b15                                                        | ACT    | DTC Active Flag                            | 0: DTC transfer operation is not in progress. 1: DTC transfer operation is in progress.                                                                                                     | R   |  |  |

### VECN[7:0] Bits (DTC-Activating Vector Number Monitoring)

While transfer by the DTC is in progress, these bits indicate the vector number corresponding to the activation source for the transfer.

When the DTCSTS register is read, the value read from the VECN[7:0] bits is valid if the value of the ACT flag was 1 (indicating DTC transfer in progress) and invalid if the value of the ACT flag was 0 (indicating no current DTC transfer). For the correspondence between the DTC activation sources and the vector addresses, refer to section 14.3.1, Interrupt Vector Table in section 14, Interrupt Controller (ICUb).

#### **ACT Flag (DTC Active Flag)**

This flag indicates the state of DTC transfer operation.

[Setting condition]

• When the DTC is activated by a transfer request.

[Clearing condition]

• When transfer by the DTC is completed in response to a transfer request.

#### 16.3 Activation Sources

The DTC is activated by an interrupt request. Setting the ICU.DTCERn.DTCE bit (n = interrupt vector number) to 1 selects the corresponding interrupt as an activation source for the DTC.

For the correspondence between the DTC activation sources and the vector addresses, refer to section 14.3.1, Interrupt Vector Table in section 14, Interrupt Controller (ICUb). For activation by software, refer to section 14.2.5, Software Interrupt Activation Register (SWINTR) in section 14, Interrupt Controller (ICUb).

Once the DTC has accepted an activation request, it does not accept another activation request until transfer for that single request is completed, regardless of the priority of the requests. When multiple activation requests are generated during DTC transfer, a request with the highest priority on completion of the transfer is accepted. When multiple activation requests are generated while the DTC module start bit (DTCST.DTCST) is 0, a request with the highest priority at the moment when the bit is subsequently set to 1 is accepted.

The DTC performs the following operations at the start of a single data transfer (or the last of the consecutive transfers in the case of a chain transfer).

- On completion of a specified round of data transfer, the ICU.DTCERn.DTCE bit is set to 0 and an interrupt is requested to the CPU.
- If the MRB.DISEL bit is 1, an interrupt is requested to the CPU on completion of data transfer.
- For the other transfers, the interrupt status flag of the activation source is set to 0 at the start of data transfer.

### 16.3.1 Allocating Transfer Information and DTC Vector Table

The DTC reads the start address of the transfer information corresponding to each activation source from the vector table and reads the transfer information starting at that address.

The vector table should be located so that the lower 10 bits of the base address (start address) are 0. Use the DTC vector base register (DTCVBR) to set the base address of the DTC vector table.

Transfer information is allocated in the RAM area. In the RAM area, the start address of the transfer information (n) with vector number n should be 4n added to the base address in the vector table.

Transfer information can be allocated in short-address mode (3 longwords) or full-address mode (4 longwords). Use the DTCADMOD.SHORT bit to select short-address mode (SHORT bit = 1) or full-address mode (SHORT bit = 0).

Figure 16.2 shows the relationship between the DTC vector table and transfer information.

Figure 16.3 shows the allocation of transfer information in the RAM area. The lower addresses vary according to the endian of the corresponding allocation area. For details, refer to section 16.9.2, Allocating Transfer Information.



Figure 16.2 DTC Vector Table and Transfer Information



Figure 16.3 Allocation of Transfer Information in the RAM Area

#### 16.4 Operation

The DTC transfers data in accordance with the transfer information. Storage of the transfer information in the RAM area is required before DTC operation.

When the DTC is activated, it reads the DTC vector corresponding to the vector number. Next, the DTC reads transfer information from the transfer information store address pointed by the DTC vector, transfers data, and then writes back the transfer information after the data transfer. Storing transfer information in the RAM area allows data transfer of arbitrary number of channels.

There are three transfer modes: normal transfer mode, repeat transfer mode, and block transfer mode.

The DTC specifies a transfer source address in the SAR register and a transfer destination address in the DAR register. The values of these registers are incremented, decremented, or address-fixed independently after data transfer.

Table 16.2 lists transfer modes of the DTC.

Table 16.2 Transfer Modes of the DTC

| Transfer Mode          | Data Size Transferred on Single Transfer Request                                      | Increment/Decrement of<br>Memory Address               | Settable Transfer<br>Count |
|------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------|----------------------------|
| Normal transfer mode   | 1 byte/1 word/1 longword                                                              | Incremented/decremented by 1, 2, or 4 or address fixed | 1 to 65536                 |
| Repeat transfer mode*1 | 1 byte/1 word/1 longword                                                              | Incremented/decremented by 1, 2, or 4 or address fixed | 1 to 256*3                 |
| Block transfer mode*2  | Block size specified in CRAH<br>(1 to 256 bytes/1 to 256 words/1 to 256<br>longwords) | Incremented/decremented by 1, 2, or 4 or address fixed | 1 to 65536                 |

Note 1. Set transfer source or transfer destination in the repeat area.

Setting the MRB.CHNE bit to 1 allows multiple transfers (chain transfer) on a single activation source. Setting the MRB.CHNS bit also enables chain transfer when specified data transfer is completed.

Figure 16.4 shows the operation flowchart of the DTC. Table 16.3 lists chain transfer conditions.

Note 2. Set transfer source or transfer destination in the block area.

Note 3. After data transfer of the specified count, the initial state is restored and the operation is continued (repeated).



Figure 16.4 Operation Flowchart of the DTC

Table 16.3 Chain Transfer Conditions

|             |             | First Tran   | sfer                                 |             | Se          | cond Trai    | nsfer* <sup>3</sup>                  |                                                                          |
|-------------|-------------|--------------|--------------------------------------|-------------|-------------|--------------|--------------------------------------|--------------------------------------------------------------------------|
| CHNE<br>Bit | CHNS<br>Bit | DISEL<br>Bit | Transfer<br>Counter* <sup>1,*2</sup> | CHNE<br>Bit | CHNS<br>Bit | DISEL<br>Bit | Transfer<br>Counter* <sup>1,*2</sup> | DTC Transfer                                                             |
| 0           | _           | 0            | Other than $(1 \rightarrow 0)$       | _           | _           | _            | _                                    | Ends after the first transfer                                            |
| 0           | _           | 0            | (1 → 0)                              | _           | _           | _            | _                                    | Ends after the first                                                     |
| 0           | _           | 1            | _                                    | _           | _           | _            | _                                    | transfer with an interrupt request to the CPU                            |
| 1           | 0           | _            | _                                    | 0           | _           | 0            | Other than $(1 \rightarrow 0)$       | Ends after the second transfer                                           |
|             |             |              |                                      | 0           | _           | 0            | (1 → 0)                              | Ends after the second                                                    |
|             |             |              |                                      | 0           | _           | 1            | _                                    | transfer with an interrupt request to the CPU                            |
| 1           | 1           | 0            | Other than (1 → *)                   | _           | _           | _            | _                                    | Ends after the first transfer                                            |
| 1           | 1           | _            | (1 → *)                              | 0           | _           | 0            | Other than (1 → 0)                   | Ends after the second transfer                                           |
|             |             |              |                                      | 0           | _           | 0            | (1 → 0)                              | Ends after the second                                                    |
|             |             |              |                                      | 0           | _           | 1            | _                                    | transfer with an interrupt request to the CPU                            |
| 1           | 1           | 1            | Other than (1 → *)                   | _           | _           | _            | _                                    | Ends after the first<br>transfer with an interrupt<br>request to the CPU |

Note 1. The transfer counters used depend on transfer modes as follows:

Normal transfer mode: CRA register Repeat transfer mode: CRAL register Block transfer mode: CRB register

Note 2. On completion of data transfer, the counters operate as follows:

 $1 \rightarrow 0$  in normal and block transfer modes

1 → CRAH in repeat transfer mode

 $(1 \rightarrow *)$  in the table indicates both of the two operations above.

Note 3. Chain transfer can be selected for the second or subsequent transfers. The condition combination of "second transfer and CHNE bit = 1" is omitted.

### 16.4.1 Transfer Information Read Skip Function

Reading of vector addresses and transfer information can be skipped by the setting of the DTCCR.RRS bit.

When a DTC activation request is generated, the current DTC vector number is compared with the DTC vector number in the previous activation process. When these vector numbers match and the RRS bit is set to 1, DTC data transfer is performed without reading the vector address and transfer information. However, when the previous transfer was chain transfer, the vector address and transfer information are read. Furthermore, when the transfer counter (CRA register) became 0 during the previous normal transfer and when the transfer counter (CRB register) became 0 during the previous block transfer, transfer information is read regardless of the value of the RRS bit. Figure 16.13 shows an example of transfer information read skip.

To update the vector table and transfer information, set the RRS bit to 0, update the vector table and transfer information, and then set the RRS bit to 1. The retained vector number is discarded by setting the RRS bit to 0. The updated DTC vector table and transfer information are read in the next activation process.

# 16.4.2 Transfer Information Write-Back Skip Function

When the MRA.SM[1:0] bits or the MRB.DM[1:0] bits are set to "address fixed", a part of transfer information is not written back. This function is performed independently of the setting of short-address mode or full-address mode. Table 16.4 lists transfer information write-back skip conditions and applicable registers.

The CRA and CRB registers are written back independently of the setting of short-address mode or full-address mode. Furthermore, in full-address mode, write-back of the MRA and MRB registers are skipped.

Table 16.4 Transfer Information Write-Back Skip Conditions and Applicable Registers

| MRA.SM | [1:0] Bits | MRB.DM | [1:0] Bits |              |              |
|--------|------------|--------|------------|--------------|--------------|
| b3     | b2         | b3     | b2         | SAR Register | DAR Register |
| 0      | 0          | 0      | 0          | Skip         | Skip         |
| 0      | 0          | 0      | 1          |              |              |
| 0      | 1          | 0      | 0          |              |              |
| 0      | 1          | 0      | 1          |              |              |
| 0      | 0          | 1      | 0          | Skip         | Write-back   |
| 0      | 0          | 1      | 1          |              |              |
| 0      | 1          | 1      | 0          |              |              |
| 0      | 1          | 1      | 1          |              |              |
| 1      | 0          | 0      | 0          | Write-back   | Skip         |
| 1      | 0          | 0      | 1          |              |              |
| 1      | 1          | 0      | 0          |              |              |
| 1      | 1          | 0      | 1          |              |              |
| 1      | 0          | 1      | 0          | Write-back   | Write-back   |
| 1      | 0          | 1      | 1          |              |              |
| 1      | 1          | 1      | 0          |              |              |
| 1      | 1          | 1      | 1          |              |              |

## 16.4.3 Normal Transfer Mode

This mode allows 1-byte, 1-word, or 1-longword data transfer on a single activation source. The transfer count can be set to 1 to 65536.

Transfer source addresses and transfer destination addresses can be set to increment, decrement, or fixed independently. This mode enables an interrupt request to the CPU to be generated at the end of specified-count transfer.

Table 16.5 lists register functions in normal transfer mode, and Figure 16.5 shows the memory map of normal transfer mode.

Table 16.5 Register Functions in Normal Transfer Mode

| Register | Description                  | Value Written Back by Writing Transfer Information |
|----------|------------------------------|----------------------------------------------------|
| SAR      | Transfer source address      | Increment/decrement/fixed*1                        |
| DAR      | Transfer destination address | Increment/decrement/fixed*1                        |
| CRA      | Transfer counter A           | CRA - 1                                            |
| CRB      | Transfer counter B           | Not updated                                        |

Note 1. Write-back operation is skipped in address-fixed mode.



Figure 16.5 Memory Map of Normal Transfer Mode

### 16.4.4 Repeat Transfer Mode

This mode allows 1-byte, 1-word, or 1-longword data transfer on a single activation source.

Specify either transfer source or transfer destination for the repeat area by the MRB.DTS bit. The transfer count can be set to 1 to 256. When the specified-count transfer is completed, the initial value of the address register specified in the transfer counter and the repeat area is restored and transfer is repeated. The other address register is incremented or decremented continuously or remains unchanged.

When the transfer counter CRAL is decreased to 00h in repeat transfer mode, the CRAL value is updated to the value set in the CRAH register. Thus the transfer counter does not become 00h, which disables an interrupt request to be generated to the CPU when the MRB.DISEL bit is set to 0 (an interrupt request to the CPU is generated when specified data transfer is completed).

Table 16.6 lists the register functions in repeat transfer mode, and Figure 16.6 shows the memory map of repeat transfer mode.

Table 16.6 Register Functions in Repeat Transfer Mode

|          |                              | Value Written Back by Writing Transfer Information |                                                                                                                |  |  |  |  |  |
|----------|------------------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Register | Description                  | When CRAL is not 1                                 | When CRAL is 1                                                                                                 |  |  |  |  |  |
| SAR      | Transfer source address      | Increment/decrement/fixed*1                        | (When the MRB.DTS bit is 0) Increment/decrement/fixed*1 (When the MRB.DTS bit is 1) SAR register initial value |  |  |  |  |  |
| DAR      | Transfer destination address | Increment/decrement/fixed*1                        | (When the MRB.DTS bit is 0) DAR register initial value (When the MRB.DTS bit is 1) Increment/decrement/fixed*1 |  |  |  |  |  |
| CRAH     | Retains transfer counter     | CRAH                                               | CRAH                                                                                                           |  |  |  |  |  |
| CRAL     | Transfer counter A           | CRAL - 1                                           | CRAH                                                                                                           |  |  |  |  |  |
| CRB      | Transfer counter B           | Not updated                                        | Not updated                                                                                                    |  |  |  |  |  |

Note 1. Write-back is skipped in address-fixed mode.



Figure 16.6 Memory Map of Repeat Transfer Mode (Transfer Source: Repeat Area)

#### 16.4.5 Block Transfer Mode

This mode allows single-block data transfer on a single activation source.

Specify either transfer source or transfer destination for the block area by the MRB.DTS bit. The block size can be set to 1 to 256 bytes, 1 to 256 words, or 1 to 256 longwords.

When transfer of the specified one block is completed, the initial values of the block size counter CRAL and the address register (the SAR register when the MRB.DTS bit = 1 or the DAR register when the DTS bit = 0) specified in the block area are restored. The other address register is incremented or decremented continuously or remains unchanged.

The transfer count (block count) can be set to 1 to 65536. This mode enables an interrupt request to the CPU to be generated at the end of specified-count block transfer.

Table 16.7 lists register functions in block transfer mode, and Figure 16.7 shows the memory map of block transfer mode.

Table 16.7 Register Functions in Block Transfer Mode

| Register | Description                  | Value Written Back by Writing Transfer Information                                                     |
|----------|------------------------------|--------------------------------------------------------------------------------------------------------|
| SAR      | Transfer source address      | (When MRB.DTS bit is 0) Increment/decrement/fixed*1 (When MRB.DTS bit is 1) SAR register initial value |
| DAR      | Transfer destination address | (When MRB.DTS bit is 0) DAR register initial value (When MRB.DTS bit is 1) Increment/decrement/fixed*1 |
| CRAH     | Retains block size           | CRAH                                                                                                   |
| CRAL     | Block size counter           | CRAH                                                                                                   |
| CRB      | Block transfer counter       | CRB - 1                                                                                                |

Note 1. Write-back is skipped in address-fixed mode.



Figure 16.7 Memory Map of Block Transfer Mode (Transfer Destination: Block Area)

#### 16.4.6 Chain Transfer

Setting the MRB.CHNE bit to 1 allows chain transfer to be performed continuously on a single activation source. If the MRB.CHNE and CHNS bits are set to 1 and 0, respectively, an interrupt request to the CPU is not generated by completion of specified number of rounds of transfer or by setting the MRB.DISEL bit to 1 (an interrupt request to the CPU is generated each time DTC data transfer is performed), and data transfer has no effect on the interrupt status flag of the activation source.

The SAR, DAR, CRA, CRB, MRA, and MRB registers can be set independently of each other to define data transfer. Figure 16.8 shows chain transfer operation.



Figure 16.8 Chain Transfer Operation

Writing 1 to the MRB.CHNE and CHNS bits enables chain transfer to be performed only after completion of specified data transfer. In repeat transfer mode, chain transfer is performed after completion of specified data transfer. For details on chain transfer conditions, refer to Table 16.3, Chain Transfer Conditions.

# 16.4.7 Operation Timing

Figure 16.9 to Figure 16.13 show examples of DTC operation timing.



Figure 16.9 Example (1) of DTC Operation Timing (Short-Address Mode, Normal Transfer Mode, Repeat Transfer Mode)



Figure 16.10 Example (2) of DTC Operation Timing (Short-Address Mode, Block Transfer Mode, Block Size = 4)



Figure 16.11 Example (3) of DTC Operation Timing (Short-Address Mode, Chain Transfer)



Figure 16.12 Example (4) of DTC Operation Timing
(Full-Address Mode, Normal Transfer Mode, Repeat Transfer Mode)



Figure 16.13 Example of Operation When Transfer Information Read Skip is Executed (Vector, Transfer Information, and Transfer Destination Data on the RAM, and Transfer Source Data on the Peripheral Module)

### 16.4.8 Execution Cycles of the DTC

Table 16.8 lists the execution cycles of single data transfer of the DTC.

For the order of the execution states, refer to section 16.4.7, Operation Timing.

Table 16.8 Execution Cycles of the DTC

| Transfer | Vector Read Transfer Information Read |     | Transfer Information      |              |       | Data Transfer |          | Internal |        |        |      |     |
|----------|---------------------------------------|-----|---------------------------|--------------|-------|---------------|----------|----------|--------|--------|------|-----|
| Mode     |                                       |     | Transfer Information Read |              | Write |               |          | Read     | Write  | Opera  | tion |     |
| Normal   | Cv + 1                                | 0*1 | 4 × Ci + 1*2              | 3 × Ci + 1*3 | 0*1   | 3 × Ci*4      | 2 × Ci*5 | Ci*6     | Cr + 1 | Cw     | 2    | 0*1 |
| Repeat   |                                       |     |                           |              |       |               |          |          | Cr + 1 | Cw     |      |     |
| Block*7  |                                       |     |                           |              |       |               |          |          | P × Cr | P × Cw |      |     |

- Note 1. When transfer information read is skipped
- Note 2. In full-address mode
- Note 3. In short-address mode
- Note 4. When neither SAR nor DAR is set to address-fixed mode
- Note 5. When SAR or DAR is set to address-fixed mode
- Note 6. When SAR and DAR are set to address-fixed mode
- Note 7. When the block size is 2 or more. If the block size is 1, the cycle number for normal transfer is applied.
- P: Block size (initial settings of CRAH and CRAL)
- Cv: Cycles for access to vector transfer information storage destination
- Ci: Cycles for access to transfer information storage destination address
- Cr: Cycles for access to data read destination
- Cw: Cycles for access to data write destination

(The unit is system clocks (ICLK) for "+ 1" in the Vector Read, Transfer Information Read, and Data Transfer Read columns and "2" in the Internal Operation column.)

(Cv, Ci, Cr, and Cw vary depending on the corresponding access destination. For the number of cycles for respective access destinations, refer to section 30, RAM, section 31, Flash Memory, and section 5, I/O Registers.)

### 16.4.9 DTC Bus Mastership Release Timing

The DTC does not release the bus mastership during transfer information read and transfer information write. While transfer information is not read or written, bus arbitration is made according to the priority determined by the bus master arbitrator.

For bus arbitration, refer to section 15, Buses.

### 16.5 DTC Setting Procedure

Before using the DTC, set the DTC vector base register (DTCVBR).

Figure 16.14 shows the procedure to set the DTC.



Figure 16.14 Procedure to Set the DTC

### 16.6 Examples of DTC Usage

#### 16.6.1 Normal Transfer

As an example of DTC usage, its employment in the reception of 128 bytes of data by an SCI is described below.

### (1) Transfer Information Setting

In the MRA register, select a fixed source address (MRA.SM[1:0] bits = 00b), normal transfer mode (MRA.MD[1:0] bits = 00b), and byte-sized transfer (MRA.SZ[1:0] bits = 00b). In the MRB register, specify incrementation of the destination address (MRB.DM[1:0] bits = 10b) and single data transfer by a single interrupt (MRB.CHNE bit = 0 and MRB.DISEL bit = 0). The MRB.DTS bit can be set to any value. Set the RDR register address of the SCI in the SAR register, the start address of the RAM area for data storage in the DAR register, and 128 (0080h) in the CRA register. The CRB register can be set to any value.

### (2) DTC Vector Table Setting

The start address of the transfer information for the RXI interrupt is set in the vector table for the DTC.

### (3) ICU Setting and DTC Module Activation

Set the corresponding ICU.DTCERn.DTCE bit to 1 and the ICU.IERi.IENj bit to 1. Set the DTCST.DTCST bit to 1.

### (4) SCI Setting

Enable the RXI interrupt by setting the SCR.RIE bit in the SCI to 1. If a reception error occurs during the SCI receive operation, further reception is not performed. Accordingly, make settings so that the CPU can accept receive error interrupts.

#### (5) DTC Transfer

Every time the reception of 1 byte by the SCI is completed, an RXI interrupt is generated to activate the DTC. The DTC transfers the received byte from the RDR of the SCI to RAM, after which the DAR register is incremented and the CRA register is decremented.

#### (6) Interrupt Handling

After 128 rounds of data transfer have been completed and the value in the CRA register becomes 0, an RXI interrupt request is generated for the CPU. Complete the process in the handling routine for this interrupt.

#### 16.6.2 Chain Transfer When the Counter = 0

The second data transfer is performed only when the transfer counter is set to 0 in the first data transfer, and the first data transfer information is repeatedly changed in the second transfer. Repeating this chain transfer enables transfers to be repeated 256 times or more.

The following shows an example of configuring a 128-Kbyte input buffer, where the input buffer is set so that its lower address starts with 0000h. Figure 16.15 shows a chain transfer when the counter = 0.

- 1. Set normal transfer mode for input data for the first data transfer. Set the following:

  Transfer source address: Fixed, the CRA register = 0000h (65,536 times), the MRB.CHNE bit = 1 (chain transfer is enabled), the MRB.CHNS bit = 1 (chain transfer is performed only when the transfer counter is 0), and the MRB.DISEL bit = 0 (an interrupt request to the CPU is generated when specified data transfer is completed).
- 2. Prepare the upper 8-bit address of the start address at every 65,536 times of the transfer destination address for the first data transfer in another area (such as ROM). For example, when setting the input buffer to 20 0000h to 21 FFFFh, prepare 21h and 20h.
- 3. For the second data transfer, set repeat transfer mode (source side: repeat area) for re-setting the transfer destination address of the first data transfer. Specify the upper 8 bits of the DAR register in the first transfer information area for the transfer destination. At this time, set the MRB.CHNE bit = 0 (chain transfer is disabled) and the MRB.DISEL bit = 0 (an interrupt request to the CPU is generated when specified data transfer is completed). When setting the input buffer mentioned above to 20 0000h to 21 FFFFh, set the transfer counter to 2.
- 4. The first data transfer is performed by an interrupt 65,536 times. When the transfer counter of the first data transfer becomes 0, the second data transfer starts. Set the upper 8 bits of the transfer source address of the first data transfer to 21h. The transfer counter (lower 16 bits) of the transfer destination address of the first data transfer is 0000h.
- 5. In succession, the first data transfer is performed by an interrupt 65,536 times specified for the first data transfer. When the transfer counter of the first data transfer becomes 0, the second data transfer starts. Set the upper 8 bits of the transfer source address of the first data transfer to 20h. The transfer counter (lower 16 bits) of the transfer destination address of the first data transfer is 0000h.
- 6. Steps 4 and 5 above are repeated infinitely. Since the second data transfer is in repeat transfer mode, no interrupt request to the CPU is generated.



Figure 16.15 Chain Transfer When the Counter = 0

## 16.7 Interrupt Source

When the DTC has finished data transfer of specified count or when data transfer with the MRB.DISEL bit set to 1 (an interrupt request to the CPU is generated each time DTC data transfer is performed) has been completed, an interrupt to the CPU is generated by the DTC activation source. Such interrupts to the CPU are controlled according to the PSW.I bit (interrupt enable) of the CPU, the PSW.IPL[3:0] bits (processor interrupt priority level), and the priority level of the interrupt controller.

#### 16.8 Low Power Consumption Function

Before making a transition to the module stop state, deep sleep mode, or software standby mode, set the DTCST.DTCST bit to 0 (DTC module stop), and then perform the following.

#### (1) Module Stop Function

Writing 1 (transition to the module-stop state is made) to the MSTPCRA.MSTPA28 bit enables the module stop function of the DTC. If DTC transfer is in progress at the time 1 is written to the MSTPCRA.MSTPA28 bit, the transition to the module stop state proceeds after DTC transfer has ended. While the MSTPCRA.MSTPA28 bit is 1, accessing the DTC registers is prohibited.

Writing 0 (release from the module-stop state) to the MSTPCRA.MSTPA28 bit releases the DTC from the module stop state.

#### (2) Deep Sleep Mode

Make settings according to the procedure under section 11.6.2.1, Entry to Deep Sleep Mode, in section 11, Low Power Consumption.

If DTC transfer operations are in progress at the time the WAIT instruction is executed, the transition to deep sleep mode follows the completion of DTC transfer.

The DTC is released from the module stop state by writing 0 to the MSTPCRA.MSTPA28 bit following recovery from deep sleep mode.

#### (3) Software Standby Mode

Make settings according to the procedure under section 11.6.3.1, Entry to Software Standby Mode, in section 11, Low Power Consumption.

If DTC transfer operations are in progress at the time the WAIT instruction is executed, the transition to software standby mode follows the completion of DTC transfer.

#### (4) Notes on Low Power Consumption Function

For the WAIT instruction and the register setting procedure, refer to section 11.7.5, Timing of WAIT Instructions in section 11, Low Power Consumption.

To perform DTC transfer after returning from a low power consumption mode, set the DTCST.DTCST bit to 1 again. To use a request that is generated in deep sleep mode or software standby mode as an interrupt request to the CPU but not as a DTC transfer request, specify the CPU as the interrupt request destination according to the description in section 14.4.3, Selecting Interrupt Request Destinations in section 14, Interrupt Controller (ICUb), and then execute the WAIT instruction.

#### 16.9 Usage Notes

#### 16.9.1 Transfer Information Start Address

Be sure to set multiples of 4 for the transfer information start addresses in the vector table. Otherwise, such addresses are accessed with their lowest 2 bits regarded as 00b.

## 16.9.2 Allocating Transfer Information

Allocate transfer data in the memory area according to the endian of the area as shown in Figure 16.16. For example, when writing CRA and CRB setting data with 16 bits in big endian, write the CRA setting data to lower address 0 and the CRB setting data to lower address 2. In little endian, write the CRB setting data to lower address 0 and the CRA setting data to lower address 2. When writing CRA and CRB setting data with 32 bits, place the CRA setting data at the MSB side and the CRB setting data at the LSB side regardless of endian, and then write the data to lower address 0.



Figure 16.16 Allocation of Transfer Information

#### 17. I/O Ports

#### 17.1 Overview

The I/O ports can function as general I/O ports, I/O pins of a peripheral module, or as input pins for an interrupt. Each pin can also be configured as an I/O pin of a peripheral module or as an input pin for an interrupt. Immediately after a reset, all pins function as input pins, and pin functions are switched by register settings. The setting of each pin is specified by the registers for the corresponding I/O port and registers for the on-chip peripheral modules.

Each port has the port direction register (PDR) that selects input or output direction, the port output data register (PODR) that holds data for output, the port input data register (PIDR) that indicates the pin states, the open drain control register y (ODRy, y = 0, 1) that selects the output type of each pin, the pull-up control register (PCR) that controls on/off of the input pull-up MOS, and the port mode register (PMR) that specifies the pin function of each port.

For details on the PMR register, refer to section 18, Multi-Function Pin Controller (MPC).

Products with 64-pin packages include port switching register A (PSRA) and products with 48-pin packages include port switching register B (PSRB).

The configuration of the I/O ports differs depending on the package. Table 17.1 lists the specifications of I/O ports, and Table 17.2 lists the port functions.

Table 17.1 I/O Port Specifications

|                | Package                      |                | Package               |                | Package               |                | Package              |                |
|----------------|------------------------------|----------------|-----------------------|----------------|-----------------------|----------------|----------------------|----------------|
| Port<br>Symbol | 64 Pins                      | Number of Pins | 48 Pins               | Number of Pins | 40 Pins               | Number of Pins | 36 Pins              | Number of Pins |
| PORT0          | P03, P05                     | 2              | Not available         | 0              | Not available         | 0              | Not available        | 0              |
| PORT1          | P14 to P17                   | 4              | P14 to P17            | 4              | P14 to P17            | 4              | P14 to P17           | 4              |
| PORT2          | P26, P27                     | 2              | P26, P27              | 2              | P26, P27              | 2              | P27                  | 1              |
| PORT3          | P30 to P32, P35              | 4              | P35                   | 1              | P32, P35              | 2              | P35                  | 1              |
| PORT4          | P40 to P44, P46              | 6              | P40 to P42, P46       | 4              | P41, P42, P46         | 3              | P41, P42             | 2              |
| PORT5          | P54, P55                     | 2              | Not available         | 0              | Not available         | 0              | Not available        | 0              |
| PORTA          | PA0, PA1, PA3,<br>PA4, PA6   | 5              | PA1, PA3, PA4,<br>PA6 | 4              | PA1, PA3, PA4,<br>PA6 | 4              | PA3, PA4, PA6        | 3              |
| PORTB          | PB0, PB1, PB3,<br>PB5 to PB7 | 6              | PB0, PB1, PB3,<br>PB5 | 4              | PB0, PB3              | 2              | PB0, PB3             | 2              |
| PORTC          | PC2 to PC7*1                 | 6              | PC4 to PC7*2          | 4              | PC4                   | 1              | PC4                  | 1              |
| PORTE          | PE0 to PE7                   | 8              | PE0 to PE4, PE7       | 6              | PE0 to PE4            | 5              | PE0 to PE4           | 5              |
| PORTH          | PH0 to PH3                   | 4              | PH0 to PH3            | 4              | PH0 to PH3            | 4              | PH0 to PH3           | 4              |
| PORTH          | PH7                          | 1              | PH7                   | 1              | Not available         | 0              | Not available        | 0              |
| PORTJ          | PJ6, PJ7                     | 2              | PJ6, PJ7              | 2              | PJ6, PJ7              | 2              | PJ6, PJ7             | 2              |
| 7              | Total number of pins         |                | Total number of pins  | 36             | Total number of pins  | 29             | Total number of pins | 25             |

Note 1. In products with 64-pin packages, port switching register A (PSRA) can be used to switch between PB6 and PC0, and PB7 and PC1.

Note 2. In products with 48-pin packages, port switching register B (PSRB) can be used to switch between PB0 and PC0, PB1 and PC1, PB3 and PC2, and PB5 and PC3.

Table 17.2 Port Functions

| Port  | Port Register        | Input Pull-up | Open Drain Output | 5-V Tolerant | I/O Level    |  |
|-------|----------------------|---------------|-------------------|--------------|--------------|--|
| PORT0 | P03, P05             | 0             | _                 | _            | VCC          |  |
| PORT1 | P14, P15             | 0             | 0                 | _            | _            |  |
|       | P16, P17             | 0             | 0                 | 0            | _            |  |
| PORT2 | P26, P27             | 0             | 0                 | _            | _            |  |
| PORT3 | P30 to P32           | 0             | 0                 | _            | _            |  |
|       | P35                  | _             | _                 | _            | _            |  |
| PORT4 | P40 to P44, P46      | _             | _                 | _            | AVCC0        |  |
| PORT5 | P54, P55             | 0             | _                 | _            | VCC          |  |
| PORTA | PA0, PA1, PA3, PA4   | 0             | 0                 | _            | <del>_</del> |  |
|       | PA6                  | 0             | 0                 | 0            | <del>_</del> |  |
| PORTB | PB1, PB3, PB5 to PB7 | 0             | 0                 | _            | _            |  |
|       | PB0                  | 0             | 0                 | 0            | <del>_</del> |  |
| PORTC | PC0 to PC7           | 0             | 0                 | _            | _            |  |
| PORTE | PE0 to PE7           | 0             | 0                 | _            | _            |  |
| PORTH | PH0 to PH3           | 0             | _                 | _            | _            |  |
|       | PH7                  | _             | _                 | _            | _            |  |
| PORTJ | PJ6 to PJ7           | _             | _                 | _            | AVCC0        |  |

Specifying input pull-up, open-drain output, or 5-V tolerance is available for other signals on pins that also function as general I/O pins.

# 17.2 I/O Port Configuration



Figure 17.1 I/O Port Configuration (1)



Figure 17.2 I/O Port Configuration (2)



Figure 17.3 I/O Port Configuration (3)



Figure 17.4 I/O Port Configuration (4)



Figure 17.5 I/O Port Configuration (5)

## 17.3 Register Descriptions

## 17.3.1 Port Direction Register (PDR)

Address(es): PORT0.PDR 0008 C000h, PORT1.PDR 0008 C001h, PORT2.PDR 0008 C002h, PORT3.PDR 0008 C003h, PORT4.PDR 0008 C004h, PORT5.PDR 0008 C005h, PORT4.PDR 0008 C00Ah, PORTB.PDR 0008 C00Bh, PORTC.PDR 0008 C00Ch, PORTE.PDR 0008 C00Eh, PORTH.PDR 0008 C011h, PORTJ.PDR 0008 C012h

| _                  | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|--------------------|----|----|----|----|----|----|----|----|
|                    | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 |
| Value after reset: | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit | Symbol | Bit Name              | Description                             | R/W |
|-----|--------|-----------------------|-----------------------------------------|-----|
| b0  | В0     | Pm0 Direction Control | 0: Input (Functions as an input pin.)   | R/W |
| b1  | B1     | Pm1 Direction Control | 1: Output (Functions as an output pin.) | R/W |
| b2  | B2     | Pm2 Direction Control | <del></del>                             | R/W |
| b3  | В3     | Pm3 Direction Control | <del></del>                             | R/W |
| b4  | B4     | Pm4 Direction Control | <del></del>                             | R/W |
| b5  | B5     | Pm5 Direction Control | <del></del>                             | R/W |
| b6  | B6     | Pm6 Direction Control | <del></del>                             | R/W |
| b7  | B7     | Pm7 Direction Control |                                         | R/W |

m = 0 to 5, A to C, E, H, J

PDR is used to select the input or output direction for individual pins of the corresponding port m when the pins are configured as the general I/O pins.

PORTm.PDR is a direction register of port m. Each bit in this register corresponds to each pin of port m and I/O direction can be specified in 1-bit units. The bits corresponding to pins that are not listed in Table 17.1 and the PORT3.PDR.B5 bit of the input-only P35 pin are reserved. A reserved bit should be set to 0 or 1 according to Table 17.3 to Table 17.6. When setting a value to a reserved bit, access in byte units.

# 17.3.2 Port Output Data Register (PODR)

Address(es): PORT0.PODR 0008 C020h, PORT1.PODR 0008 C021h, PORT2.PODR 0008 C022h, PORT3.PODR 0008 C023h, PORT4.PODR 0008 C024h, PORT5.PODR 0008 C025h, PORTA.PODR 0008 C02Ah, PORTB.PODR 0008 C02Bh, PORTC.PODR 0008 C02Ch, PORTE.PODR 0008 C02Eh, PORTH.PODR 0008 C031h, PORTJ.PODR 0008 C032h

| _                  | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|--------------------|----|----|----|----|----|----|----|----|
|                    | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 |
| Value after reset: | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit | Symbol | Bit Name              | Description        | R/W |
|-----|--------|-----------------------|--------------------|-----|
| b0  | В0     | Pm0 Output Data Store | Holds output data. | R/W |
| b1  | B1     | Pm1 Output Data Store |                    | R/W |
| b2  | B2     | Pm2 Output Data Store |                    | R/W |
| b3  | В3     | Pm3 Output Data Store |                    | R/W |
| b4  | B4     | Pm4 Output Data Store |                    | R/W |
| b5  | B5     | Pm5 Output Data Store |                    | R/W |
| b6  | B6     | Pm6 Output Data Store |                    | R/W |
| b7  | B7     | Pm7 Output Data Store |                    | R/W |

m = 0 to 5, A to C, E, H, J

PODR holds the data to be output from the pins used for general output ports.

The bits corresponding to pins that are not listed in Table 17.1 and the PORT3.PODR.B5 bit of the input-only P35 pin are reserved. A reserved bit is read as 0. The write value should be 0. When setting a value to a reserved bit, access in byte units.

## 17.3.3 Port Input Data Register (PIDR)

Address(es): PORT0.PIDR 0008 C040h, PORT1.PIDR 0008 C041h, PORT2.PIDR 0008 C042h, PORT3.PIDR 0008 C043h, PORT4.PIDR 0008 C044h, PORT5.PIDR 0008 C045h, PORT4.PIDR 0008 C044h, PORTB.PIDR 0008 C048h, PORTC.PIDR 0008 C04Ch, PORTE.PIDR 0008 C04Eh, PORTH.PIDR 0008 C051h, PORTJ.PIDR 0008 C052h

| et: | Х  | Х  | Х  | Х  | Х  | Х  | Х  | Х  |
|-----|----|----|----|----|----|----|----|----|
|     | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 |
|     | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |

x: Undefined

Value after rese

| Bit | Symbol | Bit Name | Description                                                | R/W |
|-----|--------|----------|------------------------------------------------------------|-----|
| b0  | В0     | Pm0      | Indicates individual pin states of the corresponding port. | R   |
| b1  | B1     | Pm1      |                                                            | R   |
| b2  | B2     | Pm2      |                                                            | R   |
| b3  | В3     | Pm3      |                                                            | R   |
| b4  | B4     | Pm4      |                                                            | R   |
| b5  | B5     | Pm5      |                                                            | R   |
| b6  | B6     | Pm6      |                                                            | R   |
| b7  | B7     | Pm7      |                                                            | R   |

m = 0 to 5, A to C, E, H, J

PIDR indicates individual pin states of port m.

The pin states of port m can be read with the PORTm.PIDR, regardless of the values of PORTm.PDR and PORTm.PMR. The NMI pin state is reflected in the P35 bit.

The bits corresponding to pins that are not listed in Table 17.1 are reserved. The read value of a reserved bit is undefined. Writing has no effect.

#### Notes when using PH7 as a general input port and PJ6 and PJ7 as general I/O ports

When using PH7 as a general input port, follow the procedure below to make settings.

- 1. Set the sub-clock oscillator control bit in RTC control register 3 (RCR3.RTCEN) to 0. For details on this register, refer to section 21.2.19, RTC Control Register 3 (RCR3).
- Set the sub-clock oscillator stop bit in the sub-clock oscillator control register (SOSCCR.SOSTP) to 1. For details
  on the functions and rewriting of this register, refer to section 9.2.4, Sub-Clock Oscillator Control Register
  (SOSCCR).

When using PJ6 and PJ7 as a general input port, follow the procedure below to make settings.

- 1. Set the PJ6PFS.ASEL bit to 0. (When using the PJ6 port) Set the PJ7PFS.ASEL bit to 0. (When using the PJ7 port)
- 2. Set the PORTJ.PMR.B6 to 0. (When using the PJ6 port) Set the PORTJ.PMR.B7 to 0. (When using the PJ7 port)

# 17.3.4 Port Mode Register (PMR)

Address(es): PORT0.PMR 0008 C060h, PORT1.PMR 0008 C061h, PORT2.PMR 0008 C062h, PORT3.PMR 0008 C063h, PORT4.PMR 0008 C064h, PORT5.PMR 0008 C065h, PORTA.PMR 0008 C06Ah, PORTB.PMR 0008 C06Bh, PORTC.PMR 0008 C06Ch, PORTE.PMR 0008 C06Eh, PORTH.PMR 0008 C071h, PORTJ.PMR 0008 C072h

| _                  | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|--------------------|----|----|----|----|----|----|----|----|
|                    | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 |
| Value after reset: | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit | Symbol | Bit Name             | Description                                      | R/W |
|-----|--------|----------------------|--------------------------------------------------|-----|
| b0  | В0     | Pm0 Pin Mode Control | 0: Use pin as general I/O port.                  | R/W |
| b1  | B1     | Pm1 Pin Mode Control | 1: Use pin as I/O port for peripheral functions. | R/W |
| b2  | B2     | Pm2 Pin Mode Control | <del></del>                                      | R/W |
| b3  | В3     | Pm3 Pin Mode Control | <del></del>                                      | R/W |
| b4  | B4     | Pm4 Pin Mode Control | <del></del>                                      | R/W |
| b5  | B5     | Pm5 Pin Mode Control | <del></del>                                      | R/W |
| b6  | B6     | Pm6 Pin Mode Control | <del></del>                                      | R/W |
| b7  | B7     | Pm7 Pin Mode Control |                                                  | R/W |

m = 0 to 5, A to C, E, H, J

Each bit of PORTm.PMR corresponds to each pin of port m; pin function can be specified in 1-bit units.

The bits corresponding to pins that are not listed in Table 17.1, the PORT3.PMR.B5 bit of the input-only P35 pin, and the PORTH.PMR.B7 bit of the input-only PH7 pin are reserved. A reserved bit is read as 0. The write value should be 0. When setting a value to a reserved bit, access in byte units.

However, set the PORTH.PMR.B7 bit in a product with 40 pins or less. Also, stop the sub-clock oscillator according to the handling of PH7/XCIN listed in Table 17.3.

# 17.3.5 Open Drain Control Register 0 (ODR0)

Address(es): PORT3.ODR0 0008 C086h, PORTA.ODR0 0008 C094h, PORTB.ODR0 0008 C096h, PORTC.ODR0 0008 C098h, PORTE.ODR0 0008 C09Ch

|     | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|-----|----|----|----|----|----|----|----|----|
|     | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 |
| et. | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit | Symbol | Bit Name               | Description                                                                                                                                                                                                                                                                                                     | R/W |
|-----|--------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | В0     | Pm0 Output Type Select | 0: CMOS output<br>1: N-channel open-drain output                                                                                                                                                                                                                                                                | R/W |
| b1  | B1     | Reserved               | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                                                             | R/W |
| b2  | B2     | Pm1 Output Type Select | • P31, PA1, PB1, PC1                                                                                                                                                                                                                                                                                            | R/W |
| b3  | ВЗ     | _                      | <ul> <li>b2 0: CMOS output <ul> <li>1: N-channel open-drain</li> </ul> </li> <li>b3 This bit is read as 0. The write value should be 0.</li> <li>PE1</li> <li>b3 b2</li> <li>0 0: CMOS output</li> <li>0 1: N-channel open-drain</li> <li>1 0: P-channel open-drain</li> <li>1 1: Setting prohibited</li> </ul> | R/W |
| b4  | B4     | Pm2 Output Type Select | 0: CMOS output<br>1: N-channel open-drain output                                                                                                                                                                                                                                                                | R/W |
| b5  | B5     | Reserved               | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                                                             | R/W |
| b6  | В6     | Pm3 Output Type Select | 0: CMOS output<br>1: N-channel open-drain output                                                                                                                                                                                                                                                                | R/W |
| b7  | B7     | Reserved               | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                                                             | R/W |

m = 3, A to C, E

The bits corresponding to pins that are not listed in Table 17.1 are reserved. A reserved bit is read as 0. The write value should be 0. When setting a value to a reserved bit, access in byte units.

# 17.3.6 Open Drain Control Register 1 (ODR1)

Address(es): PORT1.ODR1 0008 C083h, PORT2.ODR1 0008 C085h, PORTA.ODR1 0008 C095h, PORTB.ODR1 0008 C097h, PORTC.ODR1 0008 C099h, PORTE.ODR1 0008 C090h

| _                  | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |
|--------------------|----|----|----|----|----|----|----|----|
|                    | В7 | В6 | B5 | В4 | В3 | B2 | B1 | В0 |
| Value after reset: | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit | Symbol | Bit Name               | Description                                                                                                                                                                                               | R/W |
|-----|--------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | В0     | Pm4 Output Type Select | • PA4, PC4, PE4                                                                                                                                                                                           | R/W |
| b1  | B1     | _                      | b0 0: CMOS output 1: N-channel open-drain b1 This bit is read as 0. The write value should be 0. • P14 b1 b0 0 0: CMOS output 0 1: N-channel open-drain 1 0: P-channel open-drain 1 1: Setting prohibited | R/W |
| b2  | B2     | Pm5 Output Type Select | 0: CMOS output<br>1: N-channel open-drain output                                                                                                                                                          | R/W |
| b3  | В3     | Reserved               | This bit is read as 0. The write value should be 0.                                                                                                                                                       | R/W |
| b4  | B4     | Pm6 Output Type Select | 0: CMOS output<br>1: N-channel open-drain output                                                                                                                                                          | R/W |
| b5  | B5     | Reserved               | This bit is read as 0. The write value should be 0.                                                                                                                                                       | R/W |
| b6  | В6     | Pm7 Output Type Select | 0: CMOS output<br>1: N-channel open-drain output                                                                                                                                                          | R/W |
| b7  | B7     | Reserved               | This bit is read as 0. The write value should be 0.                                                                                                                                                       | R/W |

m = 1 to 2, A to C, E

The bits corresponding to pins that are not listed in Table 17.1 and the PORT3.ODR1.B2 bit of the input-only P35 pin are reserved. A reserved bit is read as 0. The write value should be 0. When setting a value to a reserved bit, access in byte units.

## 17.3.7 Pull-Up Control Register (PCR)

Address(es): PORT0.PCR 0008 C0C0h, PORT1.PCR 0008 C0C1h, PORT2.PCR 0008 C0C2h, PORT3.PCR 0008 C0C3h, PORT5.PCR 0008 C0C5h, PORTA.PCR 0008 C0CAh, PORTB.PCR 0008 C0CBh, PORTC.PCR 0008 C0CCh, PORTE.PCR 0008 C0CEh, PORTH.PCR 0008 C0D1h

| _4. | _  | _  | _  | ^  | ^  | _  | _  | _  |
|-----|----|----|----|----|----|----|----|----|
|     | В7 | В6 | B5 | B4 | В3 | B2 | B1 | В0 |
|     | b7 | b6 | b5 | b4 | b3 | b2 | b1 | b0 |

Value after reset:

| Bit | Symbol | Bit Name                           | Description                            | R/W |
|-----|--------|------------------------------------|----------------------------------------|-----|
| b0  | В0     | Pm0 Input Pull-Up Resistor Control | 0: Disables an input pull-up resistor. | R/W |
| b1  | B1     | Pm1 Input Pull-Up Resistor Control | 1: Enables an input pull-up resistor.  | R/W |
| b2  | B2     | Pm2 Input Pull-Up Resistor Control | _                                      | R/W |
| b3  | В3     | Pm3 Input Pull-Up Resistor Control | _                                      | R/W |
| b4  | B4     | Pm4 Input Pull-Up Resistor Control | _                                      | R/W |
| b5  | B5     | Pm5 Input Pull-Up Resistor Control | _                                      | R/W |
| b6  | B6     | Pm6 Input Pull-Up Resistor Control | _                                      | R/W |
| b7  | B7     | Pm7 Input Pull-Up Resistor Control | _                                      | R/W |

m = 0 to 3, 5, A to C, E, H

While a pin is in the input state with the corresponding bit in PORTm.PCR set to 1, the pull-up resistor connected to the pin is enabled.

When a pin is set as a general port output pin, or a peripheral function output pin, the pull-up resistor for the pin is disabled regardless of the settings of PCR.

The pull-up resistor is also disabled in the reset state.

The bits corresponding to pins that are not listed in Table 17.1 and the PORT3.PCR.B5 bit are reserved. A reserved bit is read as 0. The write value should be 0. When setting a value to a reserved bit, access in byte units.

## 17.3.8 Port Switching Register A (PSRA)

Address(es): PORT.PSRA 0008 C121h



| Bit      | Symbol | Bit Name          | Description                                                                               | R/W |
|----------|--------|-------------------|-------------------------------------------------------------------------------------------|-----|
| b5 to b0 | _      | Reserved          | This bit is read as 0. The write value should be 0.                                       | R/W |
| b6       | PSEL6  | PB6/PC0 Switching | 0: PB6 general I/O port function is selected 1: PC0 general I/O port function is selected | R/W |
| b7       | PSEL7  | PB7/PC1 Switching | 0: PB7 general I/O port function is selected 1: PC1 general I/O port function is selected | R/W |

Note: The PSRA register is for 64-pin packages.

The PSRA register is used to select either the general I/O functions of PB6 and PB7 or those of PC0 and PC1. When 1 is written to the PSEL6 and PSEL7 bits, port C can be used as an 8-bit port. Figure 17.6 shows the switching general-purpose I/O port by the PSRA register.

As for the I/O functions of the peripheral functions, functions multiplexed with PB6 and PB7 are enabled. To enable the peripheral functions, write 1 to the corresponding pin mode control bit of the PORTB.PMR register.

Rewriting this register must be performed when the PMR, PDR, and PCR registers for the corresponding pins are 0.



Figure 17.6 Example of Switching General-Purpose I/O Port by the PSRA Register

## 17.3.9 Port Switching Register B (PSRB)

Address(es): PORT.PSRB 0008 C120h



| Bit    | Symbol | Bit Name          | Description                                                                               | R/W |
|--------|--------|-------------------|-------------------------------------------------------------------------------------------|-----|
| b0     | PSEL0  | PB0/PC0 Switching | 0: PB0 general I/O port function is selected 1: PC0 general I/O port function is selected | R/W |
| b1     | PSEL1  | PB1/PC1 Switching | 0: PB1 general I/O port function is selected 1: PC1 general I/O port function is selected | R/W |
| b2     | _      | Reserved          | This bit is read as 0. The write value should be 0.                                       | R/W |
| b3     | PSEL3  | PB3/PC2 Switching | 0: PB3 general I/O port function is selected 1: PC2 general I/O port function is selected | R/W |
| b4     | _      | Reserved          | This bit is read as 0. The write value should be 0.                                       | R/W |
| b5     | PSEL5  | PB5/PC3 Switching | 0: PB5 general I/O port function is selected 1: PC3 general I/O port function is selected | R/W |
| b7, b6 | _      | Reserved          | These bits are read as 0. The write value should be 0.                                    | R/W |

Note: The PSRB register is for 48-pin packages.

The PSRB register is used to select either the general I/O functions of PB0, PB1, PB3, and PB5 and those of PC0 to PC3. When 1 is written to the PSEL0, PSEL1, PSEL3, and PSEL5 bits, port C can be used as an 8-bit port. Figure 17.7 show the switching general-purpose I/O port by the PSRA register.

As for the I/O functions of the peripheral functions, functions multiplexed with PB0, PB1, PB3, and PB5 are enabled. To enable the peripheral functions, write 1 to the corresponding pin mode control bit of the PORTB.PMR register.

Rewriting this register must be performed when the PMR, PDR, and PCR registers for the corresponding pins are 0.



Figure 17.7 Example of Switching General-Purpose I/O Port by the PSRB Register

## 17.4 Initialization of the Port Direction Register (PDR)

Initialize reserved bits in the PDR register according to Table 17.3 to Table 17.6.

• The blank columns in Table 17.3 to Table 17.6 indicate the bits corresponding to the pins listed in Table 17.1, I/O Port Specifications.

The corresponding bits should be set to 1 (output) or 0 (input) depending on the user system.

However, the PORT3.PDR.B5 bit of the input-only P35 pin and the PORTH.PDR.B7 bit of the input-only PH7 pin are reserved.

• The columns other than the blank columns in Table 17.3 to Table 17.6 indicate reserved bits. A reserved bit should be set to 0 (input) or 1 (output) according to Table 17.3 to Table 17.6. When setting a value to a reserved bit, access in byte units.

Table 17.3 PDR Register Settings in 64-Pin Packages

|             | PDR Re | PDR Register |    |    |    |    |    |    |  |  |
|-------------|--------|--------------|----|----|----|----|----|----|--|--|
| Port Symbol | b7     | b6           | b5 | b4 | b3 | b2 | b1 | b0 |  |  |
| PORT0       | 0      | 0            |    | 0  |    | 0  | 0  | 0  |  |  |
| PORT1       |        |              |    |    | 0  | 0  | 0  | 0  |  |  |
| PORT2       |        |              | 0  | 0  | 0  | 0  | 0  | 0  |  |  |
| PORT3       | 0      | 0            | 0  | 0  | 0  |    |    |    |  |  |
| PORT4       | 0      |              | 0  |    |    |    |    |    |  |  |
| PORT5       | 0      | 0            |    |    | 0  | 0  | 0  | 0  |  |  |
| PORTA       | 0      |              | 0  |    |    | 0  |    |    |  |  |
| PORTB       |        |              |    | 0  |    | 0  |    |    |  |  |
| PORTC       |        |              |    |    |    |    |    |    |  |  |
| PORTE       |        |              |    |    |    |    |    |    |  |  |
| PORTH       | 0      | 0            | 0  | 0  |    |    |    |    |  |  |
| PORTJ       |        |              | 0  | 0  | 0  | 0  | 0  | 0  |  |  |

Table 17.4 PDR Register Settings in 48-Pin Packages

| _           | PDR Re | gister |    |    |    |    |    |    |  |  |  |  |
|-------------|--------|--------|----|----|----|----|----|----|--|--|--|--|
| Port Symbol | b7     | b6     | b5 | b4 | b3 | b2 | b1 | b0 |  |  |  |  |
| PORT0       | 0      | 0      | 1  | 0  | 1  | 0  | 0  | 0  |  |  |  |  |
| PORT1       |        |        |    |    | 0  | 0  | 0  | 0  |  |  |  |  |
| PORT2       |        |        | 0  | 0  | 0  | 0  | 0  | 0  |  |  |  |  |
| PORT3       | 0      | 0      | 0  | 0  | 0  | 1  | 1  | 1  |  |  |  |  |
| PORT4       | 0      |        | 0  | 1  | 1  |    |    |    |  |  |  |  |
| PORT5       | 0      | 0      | 1  | 1  | 0  | 0  | 0  | 0  |  |  |  |  |
| PORTA       | 0      |        | 0  |    |    | 0  |    | 1  |  |  |  |  |
| PORTB       | 1      | 1      |    | 0  |    | 0  |    |    |  |  |  |  |
| PORTC       |        |        |    |    |    |    |    |    |  |  |  |  |
| PORTE       |        | 1      | 1  |    |    |    |    |    |  |  |  |  |
| PORTH       | 0      | 0      | 0  | 0  |    |    |    |    |  |  |  |  |
| PORTJ       |        |        | 0  | 0  | 0  | 0  | 0  | 0  |  |  |  |  |

Table 17.5 PDR Register Settings in 40-Pin Packages

|             | PDR Register |    |    |    |    |    |    |    |  |
|-------------|--------------|----|----|----|----|----|----|----|--|
| Port Symbol | b7           | b6 | b5 | b4 | b3 | b2 | b1 | b0 |  |
| PORT0       | 0            | 0  | 1  | 0  | 1  | 0  | 0  | 0  |  |
| PORT1       |              |    |    |    | 0  | 0  | 0  | 0  |  |
| PORT2       |              |    | 0  | 0  | 0  | 0  | 0  | 0  |  |
| PORT3       | 0            | 0  | 0  | 0  | 0  |    | 1  | 1  |  |
| PORT4       | 0            |    | 0  | 1  | 1  |    |    | 1  |  |
| PORT5       | 0            | 0  | 1  | 1  | 0  | 0  | 0  | 0  |  |
| PORTA       | 0            |    | 0  |    |    | 0  |    | 1  |  |
| PORTB       | 1            | 1  | 1  | 0  |    | 0  | 1  |    |  |
| PORTC       | 1            | 1  | 1  |    | 1  | 1  | 1  | 1  |  |
| PORTE       | 1            | 1  | 1  |    |    |    |    |    |  |
| PORTH       | 0            | 0  | 0  | 0  |    |    |    |    |  |
| PORTJ       |              |    | 0  | 0  | 0  | 0  | 0  | 0  |  |

Table 17.6 PDR Register Settings in 36-Pin Packages

|             | PDR Register |    |    |    |    |    |    |    |  |
|-------------|--------------|----|----|----|----|----|----|----|--|
| Port Symbol | b7           | b6 | b5 | b4 | b3 | b2 | b1 | b0 |  |
| PORT0       | 0            | 0  | 1  | 0  | 1  | 0  | 0  | 0  |  |
| PORT1       |              |    |    |    | 0  | 0  | 0  | 0  |  |
| PORT2       |              | 1  | 0  | 0  | 0  | 0  | 0  | 0  |  |
| PORT3       | 0            | 0  | 0  | 0  | 0  | 1  | 1  | 1  |  |
| PORT4       | 0            | 1  | 0  | 1  | 1  |    |    | 1  |  |
| PORT5       | 0            | 0  | 1  | 1  | 0  | 0  | 0  | 0  |  |
| PORTA       | 0            |    | 0  |    |    | 0  | 1  | 1  |  |
| PORTB       | 1            | 1  | 1  | 0  |    | 0  | 1  |    |  |
| PORTC       | 1            | 1  | 1  |    | 1  | 1  | 1  | 1  |  |
| PORTE       | 1            | 1  | 1  |    |    |    |    |    |  |
| PORTH       | 0            | 0  | 0  | 0  |    |    |    |    |  |
| PORTJ       |              |    | 0  | 0  | 0  | 0  | 0  | 0  |  |

# 17.5 Handling of Unused Pins

The handling of unused pins is listed in Table 17.7.

Table 17.7 Handling of Unused Pins

| Pin Name                                                   | Description                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MD                                                         | (Always used as mode pins)                                                                                                                                                                                                                                                                          |
| RES#                                                       | Connect this pin to VCC via a pull-up resistor.                                                                                                                                                                                                                                                     |
| P35/NMI                                                    | Connect this pin to VCC via a pull-up resistor.                                                                                                                                                                                                                                                     |
| EXTAL                                                      | Connect this pin to VSS via a pull-down resistor.                                                                                                                                                                                                                                                   |
| XTAL                                                       | Leave this pin open.                                                                                                                                                                                                                                                                                |
| PH7/XCIN                                                   | When the sub-clock is not used, set the RCR3.RTCEN bit to 0 and the SOSCCR.SOSTP bit to 1 (general port PH7).  When this pin is not also used as port PH7, handle it in the same way as the input setting of ports 0 to 3, 5, A to C, E, and H.                                                     |
| XCOUT                                                      | Leave this pin open.                                                                                                                                                                                                                                                                                |
| Ports 0 to 3, 5, A to C, E, H                              | <ul> <li>Set these pins to input (PORTn.PDR bit = 0) and connect each of them to VCC via a pull-up resistor or to VSS via a pull-down resistor. *1</li> <li>Set these pins to output (PORTn.PDR bit = 1), set the output data to 0 (PORTn.PODR bit = 0), and leave them open. *1, *2</li> </ul>     |
| Ports 4 and J                                              | <ul> <li>Set these pins to input (PORTn.PDR bit = 0) and connect each of them to AVCC0 via a pull-up resistor or to AVSS0 via a pull-down resistor. *1</li> <li>Set these pins to output (PORTn.PDR bit = 1), set the output data to 0 (PORTn.PODR bit = 0), and leave them open. *1, *2</li> </ul> |
| Ports 0 to 5, A to C, E, H, J (for pins that do not exist) | Set these pins to output (PORTn.PDR bit = 1), set the output data to 0 (PORTn.PODR bit = 0), and leave them open. $^{*1,*2}$ (Refer to section 17.4, Initialization of the Port Direction Register (PDR))                                                                                           |
| PJ6/VREFH0                                                 | When this pin is not used as VREFH0, set the PJ6PFS.ASEL bit to 0 (general port PJ6). When this pin is not also used as port PJ6, handle it in the same way as the handling of ports 4, J.                                                                                                          |
| PJ7/VREFL0                                                 | When this pin is not used as VREFL0, set the PJ7PFS.ASEL bit to 0 (general port PJ7). When this pin is not also used as port PJ7, handle it in the same way as the handling of ports 4, J.                                                                                                          |
| AVCC0                                                      | Connect this pin to VCC when not using the 12-bit A/D converter.                                                                                                                                                                                                                                    |
| AVSS0                                                      | Connect this pin to VSS when not using the 12-bit A/D converter.                                                                                                                                                                                                                                    |

Note 1. Set the PORTn.PMR bit to 0 and the PmnPFS.ISEL and ASEL bits to 0.

Note 2. If these ports are set to output mode and left open, they remain in input mode after the reset is released and before they are switched to output mode. The voltage level of these pins may be unstable and the power current may increase while the ports remain in input mode.

# 18. Multi-Function Pin Controller (MPC)

#### 18.1 Overview

The multi-function pin controller (MPC) is used to allocate input and output signals for peripheral modules and input interrupt signals to pins from among multiple ports.

Table 18.1 shows the allocation of pin functions to multiple pins. A and N/A in the table indicate whether the pins are available or not available on the given package. Allocating the same function to more than one pin is prohibited.

Table 18.1 Allocation of Pin Functions to Multiple Pins (1/5)

|                             |         |               |                 | Package |        |        |        |
|-----------------------------|---------|---------------|-----------------|---------|--------|--------|--------|
| Module/Function             | Channel | Pin Functions | Allocation Port | 64-pin  | 48-pin | 40-pin | 36-pin |
| Interrupt                   |         | NMI (input)   | P35             | Α       | Α      | Α      | Α      |
| Interrupt                   | IRQ0    | IRQ0 (input)  | P30             | Α       | N/A    | N/A    | N/A    |
|                             |         |               | PE0             | Α       | Α      | Α      | Α      |
|                             |         |               | PH1             | Α       | Α      | Α      | Α      |
|                             | IRQ1    | IRQ1 (input)  | P31             | Α       | N/A    | N/A    | N/A    |
|                             |         |               | PE1             | Α       | Α      | Α      | Α      |
|                             |         |               | PH2             | Α       | Α      | Α      | Α      |
|                             | IRQ2    | IRQ2 (input)  | P32             | Α       | N/A    | Α      | N/A    |
|                             |         |               | PB0             | Α       | Α      | Α      | Α      |
|                             |         |               | PC4             | Α       | Α      | Α      | Α      |
|                             | IRQ3    | IRQ3 (input)  | P27             | Α       | А      | А      | Α      |
|                             |         |               | PE3             | Α       | Α      | Α      | Α      |
|                             |         |               | PA6             | Α       | Α      | Α      | Α      |
|                             | IRQ4    | IRQ4 (input)  | P14             | Α       | Α      | Α      | Α      |
|                             |         |               | PB1             | Α       | Α      | N/A    | N/A    |
|                             |         |               | PE4             | Α       | Α      | Α      | Α      |
|                             | IRQ5    | IRQ5 (input)  | P15             | Α       | Α      | Α      | Α      |
|                             |         |               | PA4             | Α       | Α      | Α      | Α      |
|                             |         |               | PE5             | Α       | N/A    | N/A    | N/A    |
|                             | IRQ6    | IRQ6 (input)  | P16             | Α       | Α      | Α      | Α      |
|                             |         |               | PA3             | Α       | Α      | Α      | Α      |
|                             |         |               | PE6             | Α       | N/A    | N/A    | N/A    |
|                             | IRQ7    | IRQ7 (input)  | P17             | Α       | Α      | Α      | Α      |
|                             |         |               | PE2             | Α       | Α      | Α      | Α      |
|                             |         |               | PE7             | Α       | Α      | N/A    | N/A    |
| Multi-function timer unit 2 | MTU0    | MTIOC0A (I/O) | P14             | Α       | Α      | Α      | Α      |
|                             |         |               | PB3             | Α       | Α      | Α      | Α      |
|                             |         |               | PE3             | Α       | Α      | Α      | Α      |
|                             |         | MTIOC0B (I/O) | P15             | А       | Α      | Α      | Α      |
|                             |         |               | PA1             | Α       | Α      | Α      | N/A    |
|                             |         | MTIOCOC (I/O) | P17             | А       | А      | А      | Α      |
|                             |         |               | P32             | Α       | N/A    | А      | N/A    |
|                             |         |               | PB0             | Α       | А      | Α      | Α      |
|                             |         |               | PB1             | Α       | А      | N/A    | N/A    |
|                             |         | MTIOC0D (I/O) | PA3             | Α       | Α      | Α      | Α      |

Table 18.1 Allocation of Pin Functions to Multiple Pins (2/5)

|                             |         |                |                 | Package |        |        |        |
|-----------------------------|---------|----------------|-----------------|---------|--------|--------|--------|
| Module/Function             | Channel | Pin Functions  | Allocation Port | 64-pin  | 48-pin | 40-pin | 36-pin |
| Multi-function timer unit 2 | MTU1    | MTIOC1A (I/O)  | PE4             | Α       | Α      | Α      | Α      |
|                             |         |                | PH3             | Α       | Α      | Α      | Α      |
|                             |         | MTIOC1B (I/O)  | PA3             | Α       | Α      | Α      | Α      |
|                             |         |                | PB5             | Α       | Α      | N/A    | N/A    |
|                             |         |                | PE3             | Α       | Α      | Α      | Α      |
|                             |         |                | PH0             | Α       | Α      | Α      | Α      |
|                             | MTU2    | MTIOC2A (I/O)  | P26             | Α       | Α      | Α      | N/A    |
|                             |         |                | PA6             | Α       | Α      | Α      | Α      |
|                             |         |                | PB5             | Α       | Α      | N/A    | N/A    |
|                             |         |                | PE0             | А       | Α      | Α      | Α      |
|                             |         | MTIOC2B (I/O)  | P27             | А       | Α      | Α      | Α      |
|                             |         |                | PA4             | Α       | Α      | Α      | Α      |
|                             |         |                | PE5             | Α       | N/A    | N/A    | N/A    |
|                             | MTU5    | MTIC5U (input) | PA4             | Α       | Α      | Α      | Α      |
|                             |         | MTIC5V (input) | PA6             | А       | Α      | Α      | Α      |
|                             |         | MTIC5W (input) | PB0             | Α       | Α      | Α      | Α      |
| Multi-function timer unit 2 | MTU     | MTCLKA (input) | P14             | Α       | Α      | Α      | Α      |
|                             |         |                | PA4             | А       | Α      | Α      | Α      |
|                             |         |                | PC6             | А       | Α      | N/A    | N/A    |
|                             |         | MTCLKB (input) | P15             | А       | Α      | Α      | Α      |
|                             |         |                | PA6             | А       | Α      | Α      | Α      |
|                             |         |                | PC7             | Α       | Α      | N/A    | N/A    |
|                             |         | MTCLKC (input) | PA1             | Α       | Α      | А      | N/A    |
|                             |         |                | PC4             | Α       | Α      | А      | Α      |
|                             |         | MTCLKD (input) | PA3             | Α       | Α      | А      | Α      |
|                             |         |                | PC5             | Α       | Α      | N/A    | N/A    |

Table 18.1 Allocation of Pin Functions to Multiple Pins (3/5)

|                                 |         |                                                                     |                 | Package |        |        |        |
|---------------------------------|---------|---------------------------------------------------------------------|-----------------|---------|--------|--------|--------|
| Module/Function                 | Channel | Pin Functions                                                       | Allocation Port | 64-pin  | 48-pin | 40-pin | 36-pin |
| Serial communications interface | SCI1    | RXD1 (input)/                                                       | P15             | Α       | Α      | Α      | Α      |
|                                 |         | SMISO1 (I/O)/<br>SSCL1 (I/O)                                        | P30             | Α       | N/A    | N/A    | N/A    |
|                                 |         | 00021 (1/0)                                                         | PC6             | Α       | Α      | N/A    | N/A    |
|                                 |         | TXD1 (output)/                                                      | P16             | Α       | Α      | Α      | Α      |
|                                 |         | SMOSI1 (I/O)/<br>SSDA1 (I/O)                                        | P26             | Α       | Α      | Α      | N/A    |
|                                 |         | 000/11 (1/0)                                                        | PC7             | Α       | Α      | N/A    | N/A    |
|                                 |         | SCK1 (I/O)                                                          | P17             | Α       | Α      | Α      | Α      |
|                                 |         |                                                                     | P27             | Α       | Α      | Α      | Α      |
|                                 |         |                                                                     | PC5             | Α       | Α      | N/A    | N/A    |
|                                 |         | CTS1# (input)/                                                      | P14             | Α       | Α      | Α      | Α      |
|                                 |         | RTS1# (output)<br>SS1# (input)                                      | P31             | Α       | N/A    | N/A    | N/A    |
|                                 | SCI5    | RXD5 (input)/<br>SMISO5 (I/O)/<br>SSCL5 (I/O)                       | PA3             | Α       | Α      | Α      | Α      |
|                                 |         |                                                                     | PC2             | Α       | N/A    | N/A    | N/A    |
|                                 |         | TXD5 (output)/<br>SMOSI5 (I/O)/<br>SSDA5 (I/O)                      | PA4             | Α       | Α      | Α      | Α      |
|                                 |         |                                                                     | PC3             | Α       | N/A    | N/A    | N/A    |
|                                 |         | SCK5 (I/O)                                                          | PA1             | Α       | Α      | Α      | N/A    |
|                                 |         |                                                                     | PC4             | Α       | Α      | Α      | Α      |
|                                 |         | CTS5# (input)/<br>RTS5# (output)/<br>SS5# (input)                   | PA6             | А       | А      | А      | А      |
| Serial communications interface | SCI12   | SCK12 (I/O)                                                         | PE0             | Α       | Α      | Α      | Α      |
|                                 |         |                                                                     | P27             | Α       | Α      | Α      | А      |
|                                 |         | RXD12 (input)/                                                      | PE2             | Α       | Α      | Α      | Α      |
|                                 |         | SMISO12 (I/O)/<br>SSCL12 (I/O)/<br>RXDX12 (input)                   | P17             | А       | Α      | Α      | А      |
|                                 |         | TXD12 (output)/                                                     | PE1             | Α       | Α      | Α      | Α      |
|                                 |         | SMOSI12 (I/O)/<br>SSDA12 (I/O)/<br>TXDX12 (output)/<br>SIOX12 (I/O) | P14             | А       | А      | А      | А      |
|                                 |         | CTS12# (input)/<br>RTS12# (output)/<br>SS12# (input)                | PE3             | А       | А      | А      | А      |
| I <sup>2</sup> C bus interface  | RIIC0   | SCL0 (I/O)                                                          | P16             | Α       | Α      | А      | Α      |
|                                 |         |                                                                     | PB0             | Α       | Α      | А      | Α      |
|                                 |         | SDA0 (I/O)                                                          | P17             | А       | А      | А      | Α      |
|                                 |         |                                                                     | PA6             | Α       | Α      | Α      | Α      |

Table 18.1 Allocation of Pin Functions to Multiple Pins (4/5)

|                             |         |                 |                 | Package |        |        |        |
|-----------------------------|---------|-----------------|-----------------|---------|--------|--------|--------|
| Module/Function             | Channel | Pin Functions   | Allocation Port | 64-pin  | 48-pin | 40-pin | 36-pin |
| Serial peripheral interface | RSPI0   | RSPCKA (I/O)    | P15             | Α       | Α      | Α      | Α      |
|                             |         |                 | PB0             | Α       | Α      | Α      | Α      |
|                             |         |                 | PC5             | Α       | Α      | N/A    | N/A    |
|                             |         |                 | PE3             | Α       | А      | Α      | Α      |
|                             |         | MOSIA (I/O)     | P16             | Α       | Α      | А      | А      |
|                             |         |                 | PA6             | Α       | А      | А      | А      |
|                             |         |                 | PE4             | Α       | А      | А      | Α      |
|                             |         |                 | PC6             | Α       | А      | N/A    | N/A    |
|                             |         | MISOA (I/O)     | P17             | Α       | А      | А      | А      |
|                             |         |                 | PC7             | Α       | Α      | N/A    | N/A    |
|                             |         |                 | PA3             | Α       | Α      | Α      | Α      |
|                             |         | SSLA0 (I/O)     | P14             | Α       | Α      | Α      | Α      |
|                             |         |                 | PA4             | Α       | Α      | Α      | Α      |
|                             |         |                 | PC4             | Α       | Α      | Α      | Α      |
|                             |         | SSLA1 (output)  | PA0             | Α       | N/A    | N/A    | N/A    |
|                             |         | SSLA2 (output)  | PA1             | Α       | Α      | Α      | N/A    |
|                             |         | SSLA3 (output)  | PC2             | Α       | N/A    | N/A    | N/A    |
| Realtime clock              |         | RTCOUT (output) | P16             | Α       | Α      | N/A    | N/A    |
|                             |         |                 | P32             | Α       | N/A    | N/A    | N/A    |
|                             |         |                 | PB0             | Α       | Α      | N/A    | N/A    |
|                             |         |                 | PA1             | Α       | Α      | N/A    | N/A    |
| 12-bit A/D converter        |         | AN000 (input)*1 | P40             | Α       | Α      | N/A    | N/A    |
|                             |         | AN001 (input)*1 | P41             | Α       | Α      | Α      | А      |
|                             |         | AN002 (input)*1 | P42             | Α       | Α      | Α      | А      |
|                             |         | AN003 (input)*1 | P43             | Α       | N/A    | N/A    | N/A    |
|                             |         | AN004 (input)*1 | P44             | Α       | N/A    | N/A    | N/A    |
|                             |         | AN006 (input)*1 | P46             | Α       | Α      | Α      | N/A    |
|                             |         | AN008 (input)*1 | PE0             | Α       | А      | А      | Α      |
|                             |         | AN009 (input)*1 | PE1             | Α       | А      | А      | Α      |
|                             |         | AN010 (input)*1 | PE2             | Α       | А      | А      | Α      |
|                             |         | AN011 (input)*1 | PE3             | Α       | А      | А      | Α      |
|                             |         | AN012 (input)*1 | PE4             | Α       | А      | А      | Α      |
|                             |         | AN013 (input)*1 | PE5             | Α       | N/A    | N/A    | N/A    |
|                             |         | AN014 (input)*1 | PE6             | Α       | N/A    | N/A    | N/A    |
|                             |         | AN015 (input)*1 | PE7             | Α       | А      | N/A    | N/A    |
|                             |         | VREFH0 (input)  | PJ6             | Α       | А      | А      | Α      |
|                             |         | VREFL0 (input)  | PJ7             | Α       | Α      | Α      | Α      |
|                             |         | ADTRG0# (input) | P16             | Α       | А      | А      | Α      |
|                             |         |                 | P27             | Α       | Α      | А      | А      |
|                             |         |                 | PB0             | Α       | Α      | А      | Α      |
| Clock                       |         | CLKOUT (output) | P15             | Α       | А      | Α      | Α      |
|                             |         |                 | PC4             | Α       | Α      | Α      | Α      |

Table 18.1 Allocation of Pin Functions to Multiple Pins (5/5)

|                                      |         |                 |                 | Package |        |        |        |
|--------------------------------------|---------|-----------------|-----------------|---------|--------|--------|--------|
| Module/Function                      | Channel | Pin Functions   | Allocation Port | 64-pin  | 48-pin | 40-pin | 36-pin |
| Clock frequency accuracy measurement |         | CACREF (input)  | P27             | Α       | Α      | Α      | А      |
| circuit                              |         |                 | PA0             | Α       | N/A    | N/A    | N/A    |
|                                      |         |                 | PC7             | Α       | Α      | N/A    | N/A    |
|                                      |         |                 | PH0             | Α       | Α      | Α      | А      |
| Voltage detection circuit            |         | CMPA2 (input)*1 | P27             | Α       | Α      | Α      | Α      |

Note 1. Select general input (by setting the Bm bits for the given pin in the PDR and PMR for the given port to 0) for the pin if this pin function is to be used.

## 18.2 Register Descriptions

Registers and bits for pins that are not present due to differences according to the package are reserved. Write the value after a reset when writing to such bits.

## 18.2.1 Write-Protect Register (PWPR)

Address(es): 0008 C11Fh



| Bit      | Symbol | Bit Name                  | Description                                                                        | R/W |
|----------|--------|---------------------------|------------------------------------------------------------------------------------|-----|
| b5 to b0 | _      | Reserved                  | These bits are read as 0. The write value should be 0.                             | R/W |
| b6       | PFSWE  | PFS Register Write Enable | Writing to the PFS register is disabled     Writing to the PFS register is enabled | R/W |
| b7       | B0WI   | PFSWE Bit Write Disable   | Writing to the PFSWE bit is enabled     Writing to the PFSWE bit is disabled       | R/W |

#### **PFSWE Bit (PFS Register Write Enable)**

Writing to the PmnPFS register is enabled only when the PFSWE bit is set to 1. To set the PFSWE bit to 1, write 1 to the PFSWE bit after writing 0 to the B0WI bit.

#### **BOWI Bit (PFSWE Bit Write Disable)**

Writing to the PFSWE bit is enabled only when the B0WI bit is set to 0.

## 18.2.2 P1n Pin Function Control Register (P1nPFS) (n = 4 to 7)

Address(es): P14PFS 0008 C14Ch, P15PFS 0008 C14Dh, P16PFS 0008 C14Eh, P17PFS 0008 C14Fh



| Bit      | Symbol    | Bit Name                        | Description                                                                                                                                                                                                                                         | R/W |
|----------|-----------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | PSEL[4:0] | Pin Function Select             | These bits select the peripheral function. For individual pin functions, refer to the table below.                                                                                                                                                  | R/W |
| b5       | _         | Reserved                        | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                 | R/W |
| b6       | ISEL      | Interrupt Input Function Select | 0: Not used as IRQn input pin 1: Used as IRQn input pin P14: IRQ4 (64 pins, 48 pins, 40 pins, 36 pins) P15: IRQ5 (64 pins, 48 pins, 40 pins, 36 pins) P16: IRQ6 (64 pins, 48 pins, 40 pins, 36 pins) P17: IRQ7 (64 pins, 48 pins, 40 pins, 36 pins) | R/W |
| b7       | _         | Reserved                        | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                 | R/W |

The Pmn pin function control register (PmnPFS) selects the pin function.

Bits PSEL[4:0] select the peripheral function assigned to each port pin.

The ISEL bit is set when a pin is used as an IRQ input pin. This setting can be used with the combination of the peripheral function, though IRQn (external pin interrupt) of the same number should not be enabled by two or more pins. The ASEL bit is set when a pin is used as an analog pin. When switching a pin to analog using the ASEL bit, set the port mode register (PORTm.PMR) to "general I/O port", the pull-up control register (PORTm.PCR) to "input pull-up disabled", and the port direction register (PORTm.PDR) to "input". The pin state cannot be read at this point. The PmnPFS register is protected by the write protect register (PWPR). Modify the register after releasing the protection. The ISEL bit to which IRQn is not specified is reserved.

Table 18.2 Register Settings for I/O Pin Functions in 64-Pin and 48-Pin

| PSEL[4:0]                 | Pin                                            |                         |                         |                                      |  |  |  |
|---------------------------|------------------------------------------------|-------------------------|-------------------------|--------------------------------------|--|--|--|
| Settings                  | P14                                            | P15                     | P16                     | P17                                  |  |  |  |
| 00000b<br>(initial value) | Hi-Z                                           |                         |                         |                                      |  |  |  |
| 00001b                    | _                                              | MTIOC0B                 | _                       | _                                    |  |  |  |
| 00010b                    | MTCLKA                                         | MTCLKB                  | _                       | _                                    |  |  |  |
| 00011b                    | MTIOC0A                                        | _                       | _                       | MTIOC0C                              |  |  |  |
| 00111b                    | _                                              | _                       | RTCOUT                  | _                                    |  |  |  |
| 01001b                    | _                                              | CLKOUT                  | ADTRG0#                 | _                                    |  |  |  |
| 01010b                    | _                                              | RXD1<br>SMISO1<br>SSCL1 | TXD1<br>SMOSI1<br>SSDA1 | SCK1                                 |  |  |  |
| 01011b                    | CTS1#<br>RTS1#<br>SS1#                         | _                       | _                       | _                                    |  |  |  |
| 01100b                    | TXD12<br>SMOSI12<br>SSDA12<br>TXDX12<br>SIOX12 | _                       | _                       | RXD12<br>SMISO12<br>SSCL12<br>RXDX12 |  |  |  |
| 01101b                    | SSLA0                                          | RSPCKA                  | MOSIA                   | MISOA                                |  |  |  |
| 01111b                    | _                                              | _                       | SCL0                    | SDA0                                 |  |  |  |

<sup>—:</sup> Do not specify this value.

Table 18.3 Register Settings for I/O Pin Functions in 40-Pin and 36-Pin

| PSEL[4:0]                 | Pin                                            |                         |                         |                                      |  |  |  |  |
|---------------------------|------------------------------------------------|-------------------------|-------------------------|--------------------------------------|--|--|--|--|
| Settings                  | P14                                            | P15                     | P16                     | P17                                  |  |  |  |  |
| 00000b<br>(initial value) | Hi-Z                                           |                         |                         |                                      |  |  |  |  |
| 00001b                    | _                                              | MTIOC0B                 | _                       | _                                    |  |  |  |  |
| 00010b                    | MTCLKA                                         | MTCLKB                  | _                       | _                                    |  |  |  |  |
| 00011b                    | MTIOC0A                                        | _                       | _                       | MTIOC0C                              |  |  |  |  |
| 00111b                    | _                                              | _                       | _                       | _                                    |  |  |  |  |
| 01001b                    | _                                              | CLKOUT                  | ADTRG0#                 | _                                    |  |  |  |  |
| 01010b                    | _                                              | RXD1<br>SMISO1<br>SSCL1 | TXD1<br>SMOSI1<br>SSDA1 | SCK1                                 |  |  |  |  |
| 01011b                    | CTS1#<br>RTS1#<br>SS1#                         | _                       | _                       | _                                    |  |  |  |  |
| 01100b                    | TXD12<br>SMOSI12<br>SSDA12<br>TXDX12<br>SIOX12 | _                       | _                       | RXD12<br>SMISO12<br>SSCL12<br>RXDX12 |  |  |  |  |
| 01101b                    | SSLA0                                          | RSPCKA                  | MOSIA                   | MISOA                                |  |  |  |  |
| 01111b                    | _                                              | _                       | SCL0                    | SDA0                                 |  |  |  |  |

<sup>—:</sup> Do not specify this value.

# 18.2.3 P2n Pin Function Control Register (P2nPFS) (n = 6 to 7)

Address(es): P26PFS 0008 C156h, P27PFS 0008 C157h



| Bit      | Symbol    | Bit Name                        | Description                                                                                                  | R/W |
|----------|-----------|---------------------------------|--------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | PSEL[4:0] | Pin Function Select             | These bits select the peripheral function. For individual pin functions, refer to the table below.           | R/W |
| b5       | _         | Reserved                        | This bit is read as 0. The write value should be 0.                                                          | R/W |
| b6       | ISEL      | Interrupt Input Function Select | 0: Not used as IRQn input pin 1: Used as IRQn input pin P27: IRQ3 (64 pins, 48 pins, 40 pins, 36 pins)       | R/W |
| b7       | ASEL      | Analog Function Select          | 0: Used as other than an analog pin 1: Used as an analog pin P27: CMPA2 (64 pins, 48 pins, 40 pins, 36 pins) | R/W |

Table 18.4 Register Settings for I/O Pin Functions in 64-Pin, 48-Pin, and 40-Pin

| PSEL[4:0]                 | Pin                     |         |
|---------------------------|-------------------------|---------|
| Settings                  | P26                     | P27     |
| 00000b<br>(initial value) | Hi-Z                    |         |
| 00001b                    | MTIOC2A                 | MTIOC2B |
| 00111b                    | _                       | CACREF  |
| 01001b                    | _                       | ADTRG0# |
| 01010b                    | TXD1<br>SMOSI1<br>SSDA1 | SCK1    |
| 01100b                    | _                       | SCK12   |

<sup>—:</sup> Do not specify this value.

Table 18.5 Register Settings for I/O Pin Function in 36-Pin

| PSEL[4:0]                 | Pin     |
|---------------------------|---------|
| Settings                  | P27     |
| 00000b<br>(initial value) | Hi-Z    |
| 00001b                    | MTIOC2B |
| 00111b                    | CACREF  |
| 01001b                    | ADTRG0# |
| 01010b                    | SCK1    |
| 01100b                    | SCK12   |

# 18.2.4 P3n Pin Function Control Register (P3nPFS) (n = 0 to 2)

Address(es): P30PFS 0008 C158h, P31PFS 0008 C159h, P32PFS 0008 C15Ah



| Bit      | Symbol    | Bit Name                           | Description                                                                                                         | R/W |
|----------|-----------|------------------------------------|---------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | PSEL[4:0] | Pin Function Select                | These bits select the peripheral function. For individual pin functions, refer to the table below.                  | R/W |
| b5       | _         | Reserved                           | This bit is read as 0. The write value should be 0.                                                                 | R/W |
| b6       | ISEL      | Interrupt Input Function<br>Select | 0: Not used as IRQn input pin 1: Used as IRQn input pin P30: IRQ0 (64 pins) P31: IRQ1 (64 pins) P32: IRQ2 (64 pins) | R/W |
| b7       | _         | Reserved                           | This bit is read as 0. The write value should be 0.                                                                 | R/W |

Table 18.6 Register Settings for I/O Pin Function in 64-Pin

| PSEL[4:0]                 | Pin                     |                        |         |
|---------------------------|-------------------------|------------------------|---------|
| Settings                  | P30                     | P31                    | P32     |
| 00000b<br>(initial value) | Hi-Z                    |                        |         |
| 00001b                    | _                       | _                      | MTIOC0C |
| 00111b                    | _                       | _                      | RTCOUT  |
| 01010b                    | RXD1<br>SMISO1<br>SSCL1 | _                      | _       |
| 01011b                    | _                       | CTS1#<br>RTS1#<br>SS1# | _       |

<sup>—:</sup> Do not specify this value.

Table 18.7 Register Settings for I/O Pin Function in 40-Pin

| PSEL[4:0]                 | Pin     |
|---------------------------|---------|
| Settings                  | P32     |
| 00000b<br>(initial value) | Hi-Z    |
| 00001b                    | MTIOC0C |

# 18.2.5 P4n Pin Function Control Register (P4nPFS) (n = 0 to 4, 6)

Address(es): P40PFS 0008 C160h, P41PFS 0008 C161h, P42PFS 0008 C162h, P43PFS 0008 C163h, P44PFS 0008 C164h, P46PFS 0008 C166h

|       | b7   | b6 | b5 | b4 | b3 | b2 | b1 | b0 |  |
|-------|------|----|----|----|----|----|----|----|--|
|       | ASEL | _  | _  | _  | _  | _  | _  | _  |  |
| ۰t٠ ٰ | Λ    | Λ  | Λ  | Λ  | Λ  | Λ  | Λ  | 0  |  |

| Bit      | Symbol | Bit Name               | Description                                                                                                                                                                                                                                                                 | R/W |
|----------|--------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b6 to b0 | _      | Reserved               | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                                      | R/W |
| b7       | ASEL   | Analog Function Select | 0: Used as other than an analog pin 1: Used as an analog pin P40: AN002 (64 pins, 48 pins) P41: AN001 (64 pins, 48 pins, 40 pins, 36 pins) P42: AN002 (64 pins, 48 pins, 40 pins, 36 pins) P43: AN003 (64 pins) P44: AN004 (64 pins) P46: AN006 (64 pins, 48 pins, 40 pins) | R/W |

# 18.2.6 PAn Pin Function Control Register (PAnPFS) (n = 0, 1, 3, 4, 6)

Address(es): PA0PFS 0008 C190h, PA1PFS 0008 C191h, PA3PFS 0008 C193h, PA4PFS 0008 C194h, PA6PFS 0008 C196h



| Bit      | Symbol    | Bit Name                        | Description                                                                                                                                                                                          | R/W |
|----------|-----------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | PSEL[4:0] | Pin Function Select             | These bits select the peripheral function. For individual pin functions, refer to the table below.                                                                                                   | R/W |
| b5       | _         | Reserved                        | This bit is read as 0. The write value should be 0.                                                                                                                                                  | R/W |
| b6       | ISEL      | Interrupt Input Function Select | 0: Not used as IRQn input pin 1: Used as IRQn input pin PA3: IRQ6 (64 pins, 48 pins, 40 pins, 36 pins) PA4: IRQ5 (64 pins, 48 pins, 40 pins, 36 pins) PA6: IRQ3 (64 pins, 48 pins, 40 pins, 36 pins) | R/W |
| b7       | _         | Reserved                        | This bit is read as 0. The write value should be 0.                                                                                                                                                  | R/W |

Table 18.8 Register Settings for I/O Pin Function in 64-Pin

| PSEL[4:0]                 | Pin    |         |                         |                         |                        |  |  |  |
|---------------------------|--------|---------|-------------------------|-------------------------|------------------------|--|--|--|
| Settings                  | PA0    | PA1     | PA3                     | PA4                     | PA6                    |  |  |  |
| 00000b<br>(initial value) | Hi-Z   |         |                         |                         |                        |  |  |  |
| 00001b                    | _      | MTIOC0B | MTIOC0D                 | MTIC5U                  | MTIC5V                 |  |  |  |
| 00010b                    | _      | MTCLKC  | MTCLKD                  | MTCLKA                  | MTCLKB                 |  |  |  |
| 00011b                    | _      | _       | MTIOC1B                 | MTIOC2B                 | MTIOC2A                |  |  |  |
| 00111b                    | CACREF | RTCOUT  | _                       | _                       | _                      |  |  |  |
| 01010b                    | _      | SCK5    | RXD5<br>SMISO5<br>SSCL5 | TXD5<br>SMOSI5<br>SSDA5 | _                      |  |  |  |
| 01011b                    | _      | _       | _                       | _                       | CTS5#<br>RTS5#<br>SS5# |  |  |  |
| 01101b                    | SSLA1  | SSLA2   | MISOA                   | SSLA0                   | MOSIA                  |  |  |  |
| 01111b                    | _      | _       | _                       | _                       | SDA0                   |  |  |  |

<sup>—:</sup> Do not specify this value.

Table 18.9 Register Settings for I/O Pin Function in 48-Pin

| PSEL[4:0]                 | Pin     |                         |                         |                        |  |  |  |
|---------------------------|---------|-------------------------|-------------------------|------------------------|--|--|--|
| Settings                  | PA1     | PA3                     | PA4                     | PA6                    |  |  |  |
| 00000b<br>(initial value) | Hi-Z    |                         |                         |                        |  |  |  |
| 00001b                    | MTIOC0B | MTIOC0D                 | MTIC5U                  | MTIC5V                 |  |  |  |
| 00010b                    | MTCLKC  | MTCLKD                  | MTCLKA                  | MTCLKB                 |  |  |  |
| 00011b                    | _       | MTIOC1B                 | MTIOC2B                 | MTIOC2A                |  |  |  |
| 00111b                    | RTCOUT  | _                       | _                       | _                      |  |  |  |
| 01010b                    | SCK5    | RXD5<br>SMISO5<br>SSCL5 | TXD5<br>SMOSI5<br>SSDA5 | _                      |  |  |  |
| 01011b                    | _       | _                       | _                       | CTS5#<br>RTS5#<br>SS5# |  |  |  |
| 01101b                    | SSLA2   | MISOA                   | SSLA0                   | MOSIA                  |  |  |  |
| 01111b                    | _       | _                       | _                       | SDA0                   |  |  |  |

<sup>—:</sup> Do not specify this value.

Table 18.10 Register Settings for I/O Pin Function in 40-Pin

| PSEL[4:0]                 | Pin     |                         |                         |                        |  |  |  |  |
|---------------------------|---------|-------------------------|-------------------------|------------------------|--|--|--|--|
| Settings                  | PA1     | PA3                     | PA4                     | PA6                    |  |  |  |  |
| 00000b<br>(initial value) | Hi-Z    |                         |                         |                        |  |  |  |  |
| 00001b                    | MTIOC0B | MTIOC0D                 | MTIC5U                  | MTIC5V                 |  |  |  |  |
| 00010b                    | MTCLKC  | MTCLKD                  | MTCLKA                  | MTCLKB                 |  |  |  |  |
| 00011b                    | _       | MTIOC1B                 | MTIOC2B                 | MTIOC2A                |  |  |  |  |
| 00111b                    | _       | _                       | _                       | _                      |  |  |  |  |
| 01010b                    | SCK5    | RXD5<br>SMISO5<br>SSCL5 | TXD5<br>SMOSI5<br>SSDA5 | _                      |  |  |  |  |
| 01011b                    | _       | _                       | _                       | CTS5#<br>RTS5#<br>SS5# |  |  |  |  |
| 01101b                    | SSLA2   | MISOA                   | SSLA0                   | MOSIA                  |  |  |  |  |
| 01111b                    | _       | _                       | _                       | SDA0                   |  |  |  |  |

<sup>—:</sup> Do not specify this value.

Table 18.11 Register Settings for I/O Pin Function in 36-Pin

| PSEL[4:0]                 | Pin                     |                         |                        |
|---------------------------|-------------------------|-------------------------|------------------------|
| Settings                  | PA3                     | PA4                     | PA6                    |
| 00000b<br>(initial value) | Hi-Z                    |                         |                        |
| 00001b                    | MTIOC0D                 | MTIC5U                  | MTIC5V                 |
| 00010b                    | MTCLKD                  | MTCLKA                  | MTCLKB                 |
| 00011b                    | MTIOC1B                 | MTIOC2B                 | MTIOC2A                |
| 01010b                    | RXD5<br>SMISO5<br>SSCL5 | TXD5<br>SMOSI5<br>SSDA5 | _                      |
| 01011b                    | _                       | _                       | CTS5#<br>RTS5#<br>SS5# |
| 01101b                    | MISOA                   | SSLA0                   | MOSIA                  |
| 01111b                    | _                       | _                       | SDA0                   |

<sup>—:</sup> Do not specify this value.

# 18.2.7 PBn Pin Function Control Register (PBnPFS) (n = 0, 1, 3, 5 to 7)

Address(es): PB0PFS 0008 C198h, PB1PFS 0008 C199h, PB3PFS 0008 C19Bh, PB5PFS 0008 C19Dh, PB6PFS 0008 C19Eh, PB7PFS 0008 C19Fh



| Bit      | Symbol    | Bit Name                           | Description                                                                                                                         | R/W |
|----------|-----------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | PSEL[4:0] | Pin Input/Output Function          | These bits select the peripheral function. For individual pin functions, refer to the table below.                                  | R/W |
| b5       | _         | Reserved                           | This bit is read as 0. The write value should be 0.                                                                                 | R/W |
| b6       | ISEL      | Interrupt Input Function<br>Select | 0: Not used as IRQn input pin 1: Used as IRQn input pin PB0: IRQ2 (64 pins, 48 pins, 40 pins, 36 pins) PB1: IRQ4 (64 pins, 48 pins) | R/W |
| b7       | _         | Reserved                           | This bit is read as 0. The write value should be 0.                                                                                 | R/W |

Table 18.12 Register Settings for I/O Pin Function in 64-Pin

| PSEL[4:0]                 | Pin     |         |              |         |     |              |
|---------------------------|---------|---------|--------------|---------|-----|--------------|
| Settings                  | PB0     | PB1     | PB3          | PB5     | PB6 | PB7          |
| 00000b<br>(initial value) | Hi-Z    |         |              |         |     |              |
| 00001b                    | MTIC5W  | MTIOC0C | MTIOC0A      | MTIOC2A | _   | _            |
| 00010b                    | MTIOC0C | _       | <del>-</del> | MTIOC1B | _   | _            |
| 00111b                    | RTCOUT  | _       | _            | _       | _   | _            |
| 01001b                    | ADTRG0# | _       | _            | _       | _   | _            |
| 01101b                    | RSPCKA  | _       | _            | _       | _   | _            |
| 01111b                    | SCL0    | _       | _            | _       | _   | <del>_</del> |

<sup>—:</sup> Do not specify this value.

Table 18.13 Register Settings for I/O Pin Function in 48-Pin

| PSEL[4:0]                 | Pin     |         |         |         |  |  |
|---------------------------|---------|---------|---------|---------|--|--|
| Settings                  | PB0     | PB1     | PB3     | PB5     |  |  |
| 00000b<br>(initial value) | Hi-Z    |         |         |         |  |  |
| 00001b                    | MTIC5W  | MTIOC0C | MTIOC0A | MTIOC2A |  |  |
| 00010b                    | MTIOC0C | _       | _       | MTIOC1B |  |  |
| 00111b                    | RTCOUT  | _       | _       | _       |  |  |
| 01001b                    | ADTRG0# | _       | _       | _       |  |  |
| 01101b                    | RSPCKA  | _       | _       | _       |  |  |
| 01111b                    | SCL0    | _       | _       | _       |  |  |

<sup>—:</sup> Do not specify this value.

Table 18.14 Register Settings for I/O Pin Function in 40-Pin and 36-Pin

| PSEL[4:0]                 | Pin     |         |
|---------------------------|---------|---------|
| Settings                  | PB0     | PB3     |
| 00000b<br>(initial value) | Hi-Z    |         |
| 00001b                    | MTIC5W  | MTIOC0A |
| 00010b                    | MTIOC0C | _       |
| 01001b                    | ADTRG0# | _       |
| 01101b                    | RSPCKA  | _       |
| 01111b                    | SCL0    | _       |

<sup>—:</sup> Do not specify this value.

# 18.2.8 PCn Pin Function Control Register (PCnPFS) (n = 2 to 7)

Address(es): PC2PFS 0008 C1A2h, PC3PFS 0008 C1A3h, PC4PFS 0008 C1A4h, PC5PFS 0008 C1A5h, PC6PFS 0008 C1A6h, PC7PFS 0008 C1A7h



| Bit      | Symbol    | Bit Name                        | Description                                                                                            | R/W |
|----------|-----------|---------------------------------|--------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | PSEL[4:0] | Pin Input/Output Function       | These bits select the peripheral function. For individual pin functions, refer to the table below.     | R/W |
| b5       | _         | Reserved                        | These bits are read as 0. The write value should be 0.                                                 | R/W |
| b6       | ISEL      | Interrupt Input Function Select | 0: Not used as IRQn input pin 1: Used as IRQn input pin PC4: IRQ2 (64 pins, 48 pins, 40 pins, 36 pins) | R/W |
| b7       | _         | Reserved                        | This bit is read as 0. The write value should be 0.                                                    | R/W |

Table 18.15 Register Settings for I/O Pin Function in 64-Pin

| PSEL[4:0]                 | Pin                     |                         |        |        |                         |                         |  |  |
|---------------------------|-------------------------|-------------------------|--------|--------|-------------------------|-------------------------|--|--|
| Settings                  | PC2                     | PC3                     | PC4    | PC5    | PC6                     | PC7                     |  |  |
| 00000b<br>(initial value) | Hi-Z                    |                         |        |        |                         |                         |  |  |
| 00010b                    | _                       | _                       | MTCLKC | MTCLKD | MTCLKA                  | MTCLKB                  |  |  |
| 00111b                    | _                       | _                       | _      | _      | _                       | CACREF                  |  |  |
| 01001b                    | _                       | _                       | CLKOUT | _      | _                       | _                       |  |  |
| 01010b                    | RXD5<br>SMISO5<br>SSCL5 | TXD5<br>SMOSI5<br>SSDA5 | SCK5   | _      | _                       | _                       |  |  |
| 01011b                    | _                       | _                       | _      | SCK1   | RXD1<br>SMISO1<br>SSCL1 | TXD1<br>SMOSI1<br>SSDA1 |  |  |
| 01101b                    | SSLA3                   | _                       | SSLA0  | RSPCKA | MOSIA                   | MISOA                   |  |  |

<sup>—:</sup> Do not specify this value.

Table 18.16 Register Settings for I/O Pin Function in 48-Pin

| PSEL[4:0]                 | Pin    |        |                         |                         |
|---------------------------|--------|--------|-------------------------|-------------------------|
| Settings                  | PC4    | PC5    | PC6                     | PC7                     |
| 00000b<br>(initial value) | Hi-Z   |        |                         |                         |
| 00010b                    | MTCLKC | MTCLKD | MTCLKA                  | MTCLKB                  |
| 00111b                    | _      | _      | _                       | CACREF                  |
| 01001b                    | CLKOUT | _      | _                       | _                       |
| 01010b                    | SCK5   | _      | _                       | _                       |
| 01011b                    | _      | SCK1   | RXD1<br>SMISO1<br>SSCL1 | TXD1<br>SMOSI1<br>SSDA1 |
| 01101b                    | SSLA0  | RSPCKA | MOSIA                   | MISOA                   |

<sup>—:</sup> Do not specify this value.

Table 18.17 Register Settings for I/O Pin Function in 40-Pin and 36-Pin

| PSEL[4:0]                 | Pin    |
|---------------------------|--------|
| Settings                  | PC4    |
| 00000b<br>(initial value) | Hi-Z   |
| 00010b                    | MTCLKC |
| 01001b                    | CLKOUT |
| 01010b                    | SCK5   |
| 01101b                    | SSLA0  |

<sup>—:</sup> Do not specify this value.

# 18.2.9 PEn Pin Function Control Register (PEnPFS) (n = 0 to 7)

Address(es): PE0PFS 0008 C1B0h, PE1PFS 0008 C1B1h, PE2PFS 0008 C1B2h, PE3PFS 0008 C1B3h, PE4PFS 0008 C1B4h, PE5PFS 0008 C1B5h, PE6PFS 0008 C1B6h, PE7PFS 0008 C1B7h



| Bit      | Symbol    | Bit Name                        | Description                                                                                                                                                                                                                                                                                                                                                                          | R/W |
|----------|-----------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | PSEL[4:0] | PEn Pin Input/Output Function   | These bits select the peripheral function. For individual pin functions, refer to the table below.                                                                                                                                                                                                                                                                                   | R/W |
| b5       | _         | Reserved                        | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                                  | R/W |
| b6       | ISEL      | Interrupt Input Function Select | 0: Not used as IRQn input pin 1: Used as IRQn input pin PE0: IRQ0 (64 pins, 48 pins, 40 pins, 36 pins) PE1: IRQ1 (64 pins, 48 pins, 40 pins, 36 pins) PE2: IRQ7 (64 pins, 48 pins, 40 pins, 36 pins) PE3: IRQ3 (64 pins, 48 pins, 40 pins, 36 pins) PE4: IRQ4 (64 pins, 48 pins, 40 pins, 36 pins) PE5: IRQ5 (64 pins) PE6: IRQ6 (64 pins) PE7: IRQ7 (64 pins, 48 pins)              | R/W |
| b7       | ASEL      | PEn Analog Function Select      | 0: Used as other than an analog pin 1: Used as an analog pin PE0: AN008 (64 pins, 48 pins, 40 pins, 36 pins) PE1: AN009 (64 pins, 48 pins, 40 pins, 36 pins) PE2: AN010 (64 pins, 48 pins, 40 pins, 36 pins) PE3: AN011 (64 pins, 48 pins, 40 pins, 36 pins) PE4: AN012 (64 pins, 48 pins, 40 pins, 36 pins) PE5: AN013 (64 pins) PE6: AN014 (64 pins) PE7: AN015 (64 pins, 48 pins) | R/W |

Table 18.18 Register Settings for I/O Pin Function in 64-Pin

| PSEL[4:0]                 | Pin     |                                                |                                      |                           |         |         |     |     |
|---------------------------|---------|------------------------------------------------|--------------------------------------|---------------------------|---------|---------|-----|-----|
| Settings                  | PE0     | PE1                                            | PE2                                  | PE3                       | PE4     | PE5     | PE6 | PE7 |
| 00000b<br>(initial value) | Hi-Z    |                                                |                                      |                           |         |         |     |     |
| 00010b                    | MTIOC2A | _                                              | _                                    | MTIOC1B                   | MTIOC1A | MTIOC2B | _   | _   |
| 00011b                    | _       | _                                              | _                                    | MTIOC0A                   | _       | _       | _   | _   |
| 01100b                    | SCK12   | TXD12<br>SMOSI12<br>SSDA12<br>TXDX12<br>SIOX12 | RXD12<br>SMISO12<br>SSCL12<br>RXDX12 | CTS12#<br>RTS12#<br>SS12# | _       | _       | _   | _   |
| 01101b                    | _       | _                                              | _                                    | RSPCKA                    | MOSIA   | _       | _   | _   |

<sup>—:</sup> Do not specify this value.

Table 18.19 Register Settings for I/O Pin Function in 48-Pin

| PSEL[4:0]                 | Pin     |                                                |                                      |                           |         |     |
|---------------------------|---------|------------------------------------------------|--------------------------------------|---------------------------|---------|-----|
| Settings                  | PE0     | PE1                                            | PE2                                  | PE3                       | PE4     | PE7 |
| 00000b<br>(initial value) | Hi-Z    |                                                |                                      |                           |         |     |
| 00010b                    | MTIOC2A | _                                              | _                                    | MTIOC1B                   | MTIOC1A | _   |
| 00011b                    | _       | _                                              | _                                    | MTIOC0A                   | _       | _   |
| 01100b                    | SCK12   | TXD12<br>SMOSI12<br>SSDA12<br>TXDX12<br>SIOX12 | RXD12<br>SMISO12<br>SSCL12<br>RXDX12 | CTS12#<br>RTS12#<br>SS12# | _       | _   |
| 01101b                    | _       | _                                              | _                                    | RSPCKA                    | MOSIA   | _   |

<sup>—:</sup> Do not specify this value.

Table 18.20 Register Settings for I/O Pin Function in 40-Pin and 36-Pin

| PSEL[4:0]                 | Pin     |                                                |                                      |                           |         |  |  |
|---------------------------|---------|------------------------------------------------|--------------------------------------|---------------------------|---------|--|--|
| Settings                  | PE0     | PE1                                            | PE2                                  | PE3                       | PE4     |  |  |
| 00000b<br>(initial value) | Hi-Z    |                                                |                                      |                           |         |  |  |
| 00010b                    | MTIOC2A | _                                              | _                                    | MTIOC1B                   | MTIOC1A |  |  |
| 00011b                    | _       | _                                              | _                                    | MTIOC0A                   | _       |  |  |
| 01100b                    | SCK12   | TXD12<br>SMOSI12<br>SSDA12<br>TXDX12<br>SIOX12 | RXD12<br>SMISO12<br>SSCL12<br>RXDX12 | CTS12#<br>RTS12#<br>SS12# | _       |  |  |
| 01101b                    | _       | _                                              | _                                    | RSPCKA                    | MOSIA   |  |  |

<sup>—:</sup> Do not specify this value.

# 18.2.10 PHn Pin Function Control Register (PHnPFS) (n = 0 to 3)

Address(es): PH0PFS 0008 C1C8h, PH1PFS 0008 C1C9h, PH2PFS 0008 C1CAh, PH3PFS 0008 C1CBh



| Bit      | Symbol                                  | Bit Name                      | Description                                                                                                                                           | R/W |
|----------|-----------------------------------------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | PSEL[4:0]                               | PHn Pin Input/Output Function | These bits select the peripheral function. For individual pin functions, refer to the table below.                                                    | R/W |
| b5       | _                                       | Reserved                      | This bit is read as 0. The write value should be 0.                                                                                                   | R/W |
| b6       | b6 ISEL Interrupt Input Function Select |                               | 0: Not used as IRQn input pin 1: Used as IRQn input pin PH1: IRQ0 (64 pins, 48 pins, 40 pins, 36 pins) PH2: IRQ1 (64 pins, 48 pins, 40 pins, 36 pins) |     |
| b7       | _                                       | Reserved                      | This bit is read as 0. The write value should be 0.                                                                                                   | R/W |

Table 18.21 Register Settings for I/O Pin Functions in 64-Pin, 48-Pin, 40-Pin, and 36-Pin

| PSEL[4:0]                 | Pin     |     |     |         |  |  |
|---------------------------|---------|-----|-----|---------|--|--|
| Settings                  | PH0     | PH1 | PH2 | PH3     |  |  |
| 00000b<br>(initial value) | Hi-Z    |     |     |         |  |  |
| 00001b                    | MTIOC1B | _   | _   | MTIOC1A |  |  |
| 00111b                    | CACREF  | _   | _   | _       |  |  |

<sup>—:</sup> Do not specify this value.

# 18.2.11 PJn Pin Function Control Register (PJnPFS) (n = 6, 7)

Address(es): PJ6PFS 0008 C1D6h, PJ7PFS 0008 C1D7h



| Bit      | Symbol | Bit Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W |
|----------|--------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b6 to b0 | _      | Reserved               | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R/W |
| b7       | ASEL   | Analog Function Select | <ul> <li>PJ6PFS.ASEL bit (64-pin, 48-pin, 40-pin, 36-pin)</li> <li>0: The AVCC0 pin is selected as the reference power supply pin for high-electric potential</li> <li>1: The VREFH0 pin is selected as the reference power supply pin for low-electric potential.</li> <li>PJ7PFS.ASEL bit (64-pin, 48-pin, 40-pin, 36-pin)</li> <li>0: The AVSS0 pin is selected as the reference power supply ground pin for low-electric potential.</li> <li>1: The VREFL0 pin is selected as the reference power supply ground pin for high-electric potential.</li> </ul> | R/W |

## 18.3 Usage Notes

## 18.3.1 Procedure for Specifying I/O Pin Functions

Use the following procedure to specify the I/O pin functions.

- 1. Set the port mode register (PMR) to 0 to select the general I/O port function.
- 2. Set the I/O register in the peripheral module to set the I/O signal assigned to the target pin.
- 3. Set the write-protect register (PWPR) to enable writing to the Pmn pin function control register (PmnPFS) (m = 1 to 5, A to C, E, H, J, n = 0 to 7).
- 4. Specify the input/output function for the pin through the PSEL[4:0] bit settings in the PmnPFS register.
- 5. Set the PWPR.PFSWE bit to 0 to disable writing to the PmnPFS register.
- 6. Set the PMR register to 1 as necessary to switch to the selected input/output function for the pin.

## 18.3.2 Notes on MPC Register Setting

- 1. Only set the Pmn pin function control register (PmnPFS) while the PMR register for the target pin is 0. If the PmnPFS is set while the PMR register is 1, unexpected edges may be input through the input pin or unexpected pulses are output through the output pin.
- 2. Only the allowed values (functions) should be specified in the PmnPFS register. If a value that is not allowed for the register is specified, correct operation is not guaranteed.
- 3. Do not assign a single function to multiple pins through the MPC register settings.
- 4. Analog input functions for the A/D converter are multiplexed with pins of ports 4 and E. If a pin is to be used as an analog input, avoid loss of resolution by setting the given bits of the port mode register (PMR), of the port direction register (PDR) to 0, and of the pull-up control register (PCR) to 0, i.e. configuring the pin as a general input, and setting the PmnPFS.ASEL bit to 1.

5. Points to note regarding the port mode register (PMR), port direction register (PDR), and Pmn pin function control register (PmnPFS) settings for pins that have multiplexed pin functions are listed in Table 18.22.

Table 18.22 Register Settings

| ltam                      | PMR.Bn    | DDD Do | PmnPFS |      |                                                                  | Deintte Note                                                                   |  |
|---------------------------|-----------|--------|--------|------|------------------------------------------------------------------|--------------------------------------------------------------------------------|--|
| Item                      | PIVIK.DII | PDR.Bn | ASEL   | ISEL | PSEL[4:0]                                                        | Point to Note                                                                  |  |
| After a reset             | 0         | 0      | 0      | 0    | 00000b                                                           | Pins function as general input port pins after release from the reset state.   |  |
| General input ports       | 0         | 0      | 0      | 0/1  | ×                                                                | Set the ISEL bit to 1 if these are multiplexed with interrupt inputs.          |  |
| General output ports      | 0         | 1      | 0      | 0    | ×                                                                |                                                                                |  |
| Peripheral functions      | 1         | х      | 0      | 0/1  | Peripheral<br>functions<br>(see Table<br>18.2 to Table<br>18.21) | Set the ISEL bit to 1 if these are multiplexed with interrupt inputs.          |  |
| Interrupt inputs          | 0         | 0      | 0      | 1    | ×                                                                |                                                                                |  |
| NMI                       | ×         | ×      | ×      | ×*1  | ×                                                                | Register settings are not required.                                            |  |
| Analog inputs and outputs | 0         | 0      | 1      | ×*1  | ×                                                                | Set these as general input port pins so that the output buffers are turned of  |  |
| XCIN                      | 0         | 0      | ×      | ×*1  | ×                                                                | Set these as general input port pins so that the output buffers are turned off |  |

x: Setting not required.

Setting the PmnPFS.ISEL bit to 1 makes the pin capable of functioning as an IRQ pin (if the IRQ is selected from the multiplexed functions).

Note 1. The pin does not function as the IRQn input pin even if the PmnPFS.ISEL bit is set to 1.

Note: The pin state is readable when the PmnPFS.ASEL bit is 0.

Note: If the value of the PmnPFS.PSEL[4:0] bits is to be changed, do so while the PMR.Bn bit is 0.

Note: If an RIIC function is assigned to a port pin, set the PCR.Bn bit to 0; pulling up is automatically turned off for outputs from peripheral modules other than the RIIC.

## 18.3.3 Note on Using Analog Functions

When an analog function is in use, configure the pin as a general input by setting the given bits of the port mode register (PMR), of the port direction register (PDR) to 0, and of the pull-up control register (PCR) to 0, and then set the ASEL bit in the port mn pin function select register (PmnPFS) to 1.

<sup>0/1:</sup> Setting the PmnPFS.ISEL bit to 0 makes the pin incapable of functioning as an IRQ pin.

# 19. Multi-Function Timer Pulse Unit 2 (MTU2b)

In this section, "PCLK" is used to refer to PCLKB.

## 19.1 Overview

This MCU has an on-chip multi-function timer pulse unit 2 (MTU). Each unit comprises a 16-bit timer with four channels (MTU0 to MTU2, MTU5).

Table 19.1 lists the specifications of the MTU, and Table 19.2 lists the functions of the MTU. Figure 19.1 shows a block diagram of the MTU.

Table 19.1 MTU Specifications

| Item                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Pulse input/output             | 8 lines max.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Pulse input                    | 3 lines                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| Count clocks                   | Eight clocks or seven clocks for each channel (four clocks for MTU5)                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| Available operations           | <ul> <li>[MTU0 to MTU2]</li> <li>Waveform output at compare match</li> <li>Input capture function (noise filter set function)</li> <li>Counter clear operation</li> <li>Simultaneous writing to multiple timer counters (TCNT)</li> <li>Simultaneous clearing by compare match or input capture</li> <li>Simultaneous register input/output by synchronous counter operation</li> <li>A maximum of 8-phase PWM output is available in combination with synchronous operation</li> </ul> |  |
|                                | [MTU0] • Buffer operation specifiable                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|                                | <ul><li>[MTU1, MTU2]</li><li>Phase counting mode specifiable independently</li><li>Cascade connection operation</li></ul>                                                                                                                                                                                                                                                                                                                                                               |  |
|                                | <ul><li>[MTU5]</li><li>Input capture function (noise filter set function)</li><li>Counter clear operation</li></ul>                                                                                                                                                                                                                                                                                                                                                                     |  |
| Interrupt sources              | 18 sources                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| Buffer operation               | Automatic transfer of register data                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| Trigger generation             | A/D converter start trigger can be generated                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| Low power consumption function | Module stop state can be set.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |

Table 19.2 MTU Functions

| Item                        |                       | MTU0                                                                                                                                                                                                                  | MTU1                                                                    | MTU2                                                                    | MTU5                                                                                                                                              |  |
|-----------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Count clock                 |                       | PCLK/1 PCLK/4 PCLK/16 PCLK/64 MTCLKA MTCLKB MTCLKC MTCLKD                                                                                                                                                             | PCLK/1<br>PCLK/4<br>PCLK/16<br>PCLK/64<br>PCLK/256<br>MTCLKA<br>MTCLKB  | PCLK/1 PCLK/4 PCLK/16 PCLK/64 PCLK/1024 MTCLKA MTCLKB MTCLKC            | PCLK/1<br>PCLK/4<br>PCLK/16<br>PCLK/64                                                                                                            |  |
| External clo                | ocks for phase<br>ode | _                                                                                                                                                                                                                     | MTCLKA<br>MTCLKB                                                        | MTCLKC<br>MTCLKD                                                        | _                                                                                                                                                 |  |
| General re                  | gisters (TGR)         | TGRA<br>TGRB<br>TGRE                                                                                                                                                                                                  | TGRA<br>TGRB                                                            | TGRA<br>TGRB                                                            | TGRU<br>TGRV<br>TGRW                                                                                                                              |  |
| General regis               |                       | TGRC<br>TGRD<br>TGRF                                                                                                                                                                                                  | _                                                                       | _                                                                       | _                                                                                                                                                 |  |
| I/O pins                    |                       | MTIOC0A<br>MTIOC0B<br>MTIOC0C<br>MTIOC0D                                                                                                                                                                              | MTIOC1A<br>MTIOC1B                                                      | MTIOC2A<br>MTIOC2B                                                      | Input pins<br>MTIC5U<br>MTIC5V<br>MTIC5W                                                                                                          |  |
| Counter cle                 | ear function          | TGR compare match or input capture                                                                                                                                                                                    | TGR compare match or input capture                                      | TGR compare match or input capture                                      | TGR compare match or input capture                                                                                                                |  |
| Compare                     | Low output            | ✓                                                                                                                                                                                                                     | ✓                                                                       | ✓                                                                       | _                                                                                                                                                 |  |
|                             | High output           | ✓                                                                                                                                                                                                                     | ✓                                                                       | ✓                                                                       | _                                                                                                                                                 |  |
| output                      | Toggle output         | ✓                                                                                                                                                                                                                     | ✓                                                                       | ✓                                                                       | _                                                                                                                                                 |  |
| Input captu                 | ire function          | ✓                                                                                                                                                                                                                     | ✓                                                                       | ✓                                                                       | ✓                                                                                                                                                 |  |
| Synchrono                   | us operation          | ✓                                                                                                                                                                                                                     | ✓                                                                       | ✓                                                                       | _                                                                                                                                                 |  |
| PWM mode                    | e 1                   | ✓                                                                                                                                                                                                                     | ✓                                                                       | ✓                                                                       | _                                                                                                                                                 |  |
| PWM mode                    | e 2                   | ✓                                                                                                                                                                                                                     | ✓                                                                       | ✓                                                                       | _                                                                                                                                                 |  |
| AC synchrodrive mode        | onous motor           | ✓                                                                                                                                                                                                                     | _                                                                       | _                                                                       | _                                                                                                                                                 |  |
| Phase coul                  | nting mode            | _                                                                                                                                                                                                                     | ✓                                                                       | ✓                                                                       | _                                                                                                                                                 |  |
| Buffer oper                 | ration                | ✓                                                                                                                                                                                                                     | _                                                                       | _                                                                       | _                                                                                                                                                 |  |
| DTC activa                  | ation                 | TGR compare match or input capture                                                                                                                                                                                    | TGR compare match or input capture                                      | TGR compare match or input capture                                      | TGR compare match or input capture                                                                                                                |  |
| A/D converter start trigger |                       | TGRA compare match or input capture TGRB compare match or input capture TGRE compare match TGRF compare match                                                                                                         | TGRA compare match or input capture                                     | TGRA compare match or input capture                                     | _                                                                                                                                                 |  |
| Interrupt sources           |                       | 7 sources Compare match or input capture 0A Compare match or input capture 0B Compare match or input capture 0C Compare match or input capture 0C Compare match or input capture 0D Compare match 0E Compare match 0F | Compare match or input capture 1A     Compare match or input capture 1B | Compare match or input capture 2A     Compare match or input capture 2B | 3 sources Compare match or input capture 5U Compare match or input capture 5V Compare match or input capture 5V Compare match or input capture 5W |  |
|                             |                       | Overflow                                                                                                                                                                                                              | <ul><li>Overflow</li><li>Underflow</li></ul>                            | <ul><li>Overflow</li><li>Underflow</li></ul>                            |                                                                                                                                                   |  |
|                             |                       |                                                                                                                                                                                                                       | - Officernow                                                            | - Ondernow                                                              |                                                                                                                                                   |  |

<sup>√:</sup> Possible

Note 1. For details on the module stop function, refer to section 11, Low Power Consumption.

<sup>—:</sup> Not possible



Figure 19.1 MTU Block Diagram

Table 19.3 lists the I/O pins to be used by the MTU.

Table 19.3 MTU I/O Pins

| Module Symbol | Pin Name | I/O   | Function                                                            |
|---------------|----------|-------|---------------------------------------------------------------------|
| MTU           | MTCLKA   | Input | External clock A input pin (MTU1 phase counting mode A phase input) |
|               | MTCLKB   | Input | External clock B input pin (MTU1 phase counting mode B phase input) |
|               | MTCLKC   | Input | External clock C input pin (MTU2 phase counting mode A phase input) |
|               | MTCLKD   | Input | External clock D input pin (MTU2 phase counting mode B phase input) |
| MTU0          | MTIOC0A  | I/O   | MTU0.TGRA input capture input/output compare output/PWM output pin  |
|               | MTIOC0B  | I/O   | MTU0.TGRB input capture input/output compare output/PWM output pin  |
|               | MTIOC0C  | I/O   | MTU0.TGRC input capture input/output compare output/PWM output pin  |
|               | MTIOC0D  | I/O   | MTU0.TGRD input capture input/output compare output/PWM output pin  |
| MTU1          | MTIOC1A  | I/O   | MTU1.TGRA input capture input/output compare output/PWM output pin  |
|               | MTIOC1B  | I/O   | MTU1.TGRB input capture input/output compare output/PWM output pin  |
| MTU2          | MTIOC2A  | I/O   | MTU2.TGRA input capture input/output compare output/PWM output pin  |
|               | MTIOC2B  | I/O   | MTU2.TGRB input capture input/output compare output/PWM output pin  |
| MTU5          | MTIC5U   | Input | MTU5.TGRU input capture input/external pulse input pin              |
|               | MTIC5V   | Input | MTU5.TGRV input capture input/external pulse input pin              |
|               | MTIC5W   | Input | MTU5.TGRW input capture input/external pulse input pin              |

## 19.2 Register Descriptions

## 19.2.1 Timer Control Register (TCR)

• MTU0.TCR, MTU1.TCR, MTU2.TCR

Address(es): MTU0.TCR 0008 8700h, MTU1.TCR 0008 8780h, MTU2.TCR 0008 8800h



| Bit      | Symbol    | Bit Name              | Description                                                                         | R/W |
|----------|-----------|-----------------------|-------------------------------------------------------------------------------------|-----|
| b2 to b0 | TPSC[2:0] | Time Prescaler Select | Refer to Table 19.6 to Table 19.8.                                                  | R/W |
| b4, b3   | CKEG[1:0] | Clock Edge Select     | b4 b3 0 0: Count at rising edge 0 1: Count at falling edge 1 x: Count at both edges | R/W |
| b7 to b5 | CCLR[2:0] | Counter Clear         | Refer to Table 19.4 and Table 19.5.                                                 | R/W |

#### x: Don't care

## • MTU5.TCRU, MTU5.TCRV, MTU5.TCRW

Address(es): MTU5.TCRU 0008 8884h, MTU5.TCRV 0008 8894h, MTU5.TCRW 0008 88A4h



| Bit      | Symbol    | Bit Name              | Description                                            | R/W |
|----------|-----------|-----------------------|--------------------------------------------------------|-----|
| b1, b0   | TPSC[1:0] | Time Prescaler Select | Refer to Table 19.9.                                   | R/W |
| b7 to b2 | _         | Reserved              | These bits are read as 0. The write value should be 0. | R/W |

The MTU has a total of six TCR registers, one each for MTU0 to MTU2 and three (TCRU, TCRV, and TCRW) for MTU5.

The TCR register controls the TCNT operation for each channel. The TCR register values should be specified only while the TCNT operation is stopped.

#### TPSC[2:0] Bits (Time Prescaler Select)

These bits select the TCNT count clock source. The count clock source can be selected independently for each channel. Refer to Table 19.6 to Table 19.9 for details.

## CKEG[1:0] Bits (Clock Edge Select)

These bits select the clock edge. When the internal clock is counted at both edges, the count clock period is halved (e.g. PCLK/4 at both edges = PCLK/2 at rising edge). If phase counting mode is used on MTU1 and MTU2, the setting of these bits is ignored and the phase counting mode setting has priority. Internal clock edge selection is valid when the count clock source is PCLK/4 or slower. When PCLK/1 or the overflow/underflow in another channel is selected for the count clock source, a value can be written to these bits but counter operation compiles with the initial value.



## CCLR[2:0] Bits (Counter Clear)

These bits select the TCNT counter clearing source. Refer to Table 19.4 and Table 19.5 for details.

Table 19.4 CCLR[2:0] (MTU0)

|         | Bit 7   | Bit 6   | Bit 5   |                                                                                                             |
|---------|---------|---------|---------|-------------------------------------------------------------------------------------------------------------|
| Channel | CCLR[2] | CCLR[1] | CCLR[0] | Description                                                                                                 |
| MTU0    | 0       | 0       | 0       | TCNT clearing disabled                                                                                      |
|         | 0       | 0       | 1       | TCNT cleared by TGRA compare match/input capture                                                            |
|         | 0       | 1       | 0       | TCNT cleared by TGRB compare match/input capture                                                            |
|         | 0       | 1       | 1       | TCNT cleared by counter clearing in another channel performing synchronous clearing/synchronous operation*1 |
|         | 1       | 0       | 0       | TCNT clearing disabled                                                                                      |
|         | 1       | 0       | 1       | TCNT cleared by TGRC compare match/input capture*2                                                          |
|         | 1       | 1       | 0       | TCNT cleared by TGRD compare match/input capture*2                                                          |
|         | 1       | 1       | 1       | TCNT cleared by counter clearing in another channel performing synchronous clearing/synchronous operation*1 |

Note 1. Synchronous operation is selected by setting the TSYR.SYNC0 bit to 1.

Table 19.5 CCLR[2:0] (MTU1 and MTU2)

|         | Bit 7      | Bit 6   | Bit 5   |                                                                                                             |
|---------|------------|---------|---------|-------------------------------------------------------------------------------------------------------------|
| Channel | Reserved*2 | CCLR[1] | CCLR[0] | Description                                                                                                 |
| MTU1,   | 0          | 0       | 0       | TCNT clearing disabled                                                                                      |
| MTU2    | 0          | 0       | 1       | TCNT cleared by TGRA compare match/input capture                                                            |
|         | 0          | 1       | 0       | TCNT cleared by TGRB compare match/input capture                                                            |
|         | 0          | 1       | 1       | TCNT cleared by counter clearing in another channel performing synchronous clearing/synchronous operation*1 |

Note 1. Synchronous operation is selected by setting the TSYR.SYNCn bit (n = 1, 2) to 1.

Table 19.6 TPSC[2:0] (MTU0)

|         | Bit 2   | Bit 1   | Bit 0   |                                            |
|---------|---------|---------|---------|--------------------------------------------|
| Channel | TPSC[2] | TPSC[1] | TPSC[0] | Description                                |
| MTU0    | 0       | 0       | 0       | Internal clock: counts on PCLK/1           |
|         | 0       | 0       | 1       | Internal clock: counts on PCLK/4           |
|         | 0       | 1       | 0       | Internal clock: counts on PCLK/16          |
|         | 0       | 1       | 1       | Internal clock: counts on PCLK/64          |
|         | 1       | 0       | 0       | External clock: counts on MTCLKA pin input |
|         | 1       | 0       | 1       | External clock: counts on MTCLKB pin input |
|         | 1       | 1       | 0       | External clock: counts on MTCLKC pin input |
|         | 1       | 1       | 1       | External clock: counts on MTCLKD pin input |

Note 2. When TGRC or TGRD is used as a buffer register, TCNT is not cleared because the buffer register setting has priority and compare match/input capture does not occur.

Note 2. Bit 7 is reserved in MTU1 and MTU2. This bit is read as 0. The write value should be 0.

Table 19.7 TPSC[2:0] (MTU1)

|         | Bit 2   | Bit 1   | Bit 0   |                                            |
|---------|---------|---------|---------|--------------------------------------------|
| Channel | TPSC[2] | TPSC[1] | TPSC[0] | Description                                |
| MTU1    | 0       | 0       | 0       | Internal clock: counts on PCLK/1           |
|         | 0       | 0       | 1       | Internal clock: counts on PCLK/4           |
|         | 0       | 1       | 0       | Internal clock: counts on PCLK/16          |
|         | 0       | 1       | 1       | Internal clock: counts on PCLK/64          |
|         | 1       | 0       | 0       | External clock: counts on MTCLKA pin input |
|         | 1       | 0       | 1       | External clock: counts on MTCLKB pin input |
|         | 1       | 1       | 0       | Internal clock: counts on PCLK/256         |
|         | 1       | 1       | 1       | Counts on MTU2.TCNT overflow/underflow     |

Note: This setting is ignored when MTU1 is in phase counting mode.

Table 19.8 TPSC[2:0] (MTU2)

|         | Bit 2   | Bit 1   | Bit 0   |                                            |
|---------|---------|---------|---------|--------------------------------------------|
| Channel | TPSC[2] | TPSC[1] | TPSC[0] | Description                                |
| MTU2    | 0       | 0       | 0       | Internal clock: counts on PCLK/1           |
|         | 0       | 0       | 1       | Internal clock: counts on PCLK/4           |
|         | 0       | 1       | 0       | Internal clock: counts on PCLK/16          |
|         | 0       | 1       | 1       | Internal clock: counts on PCLK/64          |
|         | 1       | 0       | 0       | External clock: counts on MTCLKA pin input |
|         | 1       | 0       | 1       | External clock: counts on MTCLKB pin input |
|         | 1       | 1       | 0       | External clock: counts on MTCLKC pin input |
|         | 1       | 1       | 1       | Internal clock: counts on PCLK/1024        |

Note: This setting is ignored when MTU2 is in phase counting mode.

Table 19.9 TPSC[1:0] (MTU5)

|         | Bit 1   | Bit 0   |                                   |
|---------|---------|---------|-----------------------------------|
| Channel | TPSC[1] | TPSC[0] | Description                       |
| MTU5    | 0       | 0       | Internal clock: counts on PCLK/1  |
|         | 0       | 1       | Internal clock: counts on PCLK/4  |
|         | 1       | 0       | Internal clock: counts on PCLK/16 |
|         | 1       | 1       | Internal clock: counts on PCLK/64 |

## 19.2.2 Timer Mode Register (TMDR)

Address(es): MTU0.TMDR 0008 8701h, MTU1.TMDR 0008 8781h, MTU2.TMDR 0008 8801h



| Bit      | Symbol Bit Name |                                                                                                                               | Description                                                                         |     |  |
|----------|-----------------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----|--|
| b3 to b0 | MD[3:0]         | Mode Select                                                                                                                   | These bits specify the timer operating mode. Refer to Table 19.10 for details.      | R/W |  |
| b4       | BFA             | Buffer Operation A                                                                                                            | TGRA and TGRC operate normally     TGRA and TGRC used together for buffer operation | R/W |  |
| b5       | BFB             | Buffer Operation B                                                                                                            | TGRB and TGRD operate normally     TGRB and TGRD used together for buffer operation | R/W |  |
| b6       | BFE             | Buffer Operation E  0: MTU0.TGRE and MTU0.TGRF operate normally 1: MTU0.TGRE and MTU0.TGRF used together for buffer operation |                                                                                     | R/W |  |
| b7       | _               | Reserved                                                                                                                      | This bit is read as 0. The write value should be 0.                                 |     |  |

The TMDR register specifies the operating mode of each channel. The TMDR register values should be specified only while the TCNT operation is stopped.

Table 19.10 Operating Mode Setting by MD[3:0] Bits

| Bit 3 | Bit 2 | Bit 1 | Bit 0 |                       |      |      |      |
|-------|-------|-------|-------|-----------------------|------|------|------|
| MD[3] | MD[2] | MD[1] | MD[0] | Description           | MTU0 | MTU1 | MTU2 |
| 0     | 0     | 0     | 0     | Normal mode           | ✓    | ✓    | ✓    |
| 0     | 0     | 0     | 1     | Setting prohibited    |      |      |      |
| 0     | 0     | 1     | 0     | PWM mode 1            | ✓    | ✓    | ✓    |
| 0     | 0     | 1     | 1     | PWM mode 2            | ✓    | ✓    | ✓    |
| 0     | 1     | 0     | 0     | Phase counting mode 1 |      | ✓    | ✓    |
| 0     | 1     | 0     | 1     | Phase counting mode 2 |      | ✓    | ✓    |
| 0     | 1     | 1     | 0     | Phase counting mode 3 |      | ✓    | ✓    |
| 0     | 1     | 1     | 1     | Phase counting mode 4 |      | ✓    | ✓    |
| 1     | х     | х     | х     | Setting prohibited    |      |      |      |

x: Don't care

Note: Only set the corresponding operating mode listed above for each channel.

#### **BFA Bit (Buffer Operation A)**

This bit specifies normal operation for the TGRA register or buffered operation of the combination of registers TGRA and TGRC. When the TGRC register is used as a buffer register, the TGRC input capture/output compare does not take place.

In MTU1 and MTU2, which have no TGRC register, this bit is reserved. It is read as 0. The write value should be 0.

#### **BFB Bit (Buffer Operation B)**

This bit specifies normal operation for the TGRB register or buffered operation of the combination of registers TGRB and TGRD. When the TGRD register is used as a buffer register, the TGRD input capture/output compare does not take place.

In MTU1 and MTU2, which have no TGRD register, this bit is reserved. It is read as 0. The write value should be 0.



## **BFE Bit (Buffer Operation E)**

This bit specifies normal operation or buffered operation for registers MTU0.TGRE and MTU0.TGRF. Compare match with the TGRF register occurs even when the TGRF register is used as a buffer register.

In MTU1 to MTU2, this bit is reserved. It is read as 0. The write value should be 0.



## 19.2.3 Timer I/O Control Register (TIOR)

## • MTU0.TIORH, MTU1.TIOR, MTU2.TIOR

Address(es): MTU0.TIORH 0008 8702h, MTU1.TIOR 0008 8782h, MTU2.TIOR 0008 8802h



| Bit      | Symbol   | Bit Name      | Description                                                                                                     | R/W |  |
|----------|----------|---------------|-----------------------------------------------------------------------------------------------------------------|-----|--|
| b3 to b0 | IOA[3:0] | I/O Control A | Refer to the following tables.*1 MTU0.TIORH: Table 19.15 MTU1.TIOR: Table 19.17 MTU2.TIOR: Table 19.18          | R/W |  |
| b7 to b4 | IOB[3:0] | I/O Control B | Refer to the following tables.*1<br>MTU0.TIORH: Table 19.11<br>MTU1.TIOR: Table 19.13<br>MTU2.TIOR: Table 19.14 | R/W |  |

Note 1. If the IOm[3:0] (m = A, B) bits are changed to an "output prohibited" setting (0000b or 0100b) while output of the low or high level or toggling of the output in response to compare matches is in progress, the output becomes high-impedance.

#### MTU0.TIORL

Address(es): MTU0.TIORL 0008 8703h



| Bit      | Symbol   | Bit Name      | Description                                             | R/W |
|----------|----------|---------------|---------------------------------------------------------|-----|
| b3 to b0 | IOC[3:0] | I/O Control C | Refer to the following table.*1 MTU0.TIORL: Table 19.16 | R/W |
| b7 to b4 | IOD[3:0] | I/O Control D | Refer to the following table.*1 MTU0.TIORL: Table 19.12 | R/W |

Note 1. If the IOm[3:0] (m = C, D) bits are changed to an "output prohibited" setting (0000b or 0100b) while output of the low or high level or toggling of the output in response to compare matches is in progress, the output becomes high-impedance.

#### MTU5.TIORU, MTU5.TIORV, MTU5.TIORW

Address(es): MTU5.TIORU 0008 8886h, MTU5.TIORV 0008 8896h, MTU5.TIORW 0008 88A6h



| Bit      | Symbol   | Bit Name      | Description                                                                      | R/W |
|----------|----------|---------------|----------------------------------------------------------------------------------|-----|
| b4 to b0 | IOC[4:0] | I/O Control C | Refer to the following table.<br>MTU5.TIORU, MTU5.TIORV, MTU5.TIORW: Table 19.19 | R/W |
| b7 to b5 | _        | Reserved      | These bits are read as 0. The write value should be 0.                           | R/W |

The MTU has a total of seven TIOR registers, two for MTU0, one each for MTU1 and MTU2, and three (MTU5.TIORU/TIORV/TIORW) for MTU5.

The initial output specified by the TIOR register is valid when the counter is stopped (the TSTR.CST bit is set to 0). Note also that, in PWM mode 2, the output at the point at which the counter is set to 0 is specified.

When the TGRC or TGRD register is designated for buffer operation, this setting is invalid and the register operates as a buffer register.

Table 19.11 TIORH (MTU0)

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Description             |                                                                                                |
|--------|--------|--------|--------|-------------------------|------------------------------------------------------------------------------------------------|
| IOB[3] | IOB[2] | IOB[1] | IOB[0] | MTU0.TGRB Function      | MTIOC0B Pin Function                                                                           |
| 0      | 0      | 0      | 0      | Output compare register | Output prohibited                                                                              |
| 0      | 0      | 0      | 1      | _                       | Initial output is low. Low output at compare match.                                            |
| 0      | 0      | 1      | 0      | _                       | Initial output is low. High output at compare match.                                           |
| 0      | 0      | 1      | 1      | _                       | Initial output is low. Toggle output at compare match.                                         |
| 0      | 1      | 0      | 0      | _                       | Output prohibited                                                                              |
| 0      | 1      | 0      | 1      | _                       | Initial output is high. Low output at compare match.                                           |
| 0      | 1      | 1      | 0      | _                       | Initial output is high. High output at compare match.                                          |
| 0      | 1      | 1      | 1      | _                       | Initial output is high. Toggle output at compare match.                                        |
| 1      | 0      | 0      | 0      | Input capture register  | Input capture at rising edge.                                                                  |
| 1      | 0      | 0      | 1      | _                       | Input capture at falling edge.                                                                 |
| 1      | 0      | 1      | Х      | _                       | Input capture at both edges.                                                                   |
| 1      | 1      | Х      | х      | _                       | Capture input source is count clock in MTU1. Input capture at MTU1.TCNT up-count/down-count.*1 |

x: Don't care

Note 1. When PCLK/1 is selected as the count clock for MTU1, MTU0 input capture is not generated. Do not select PCLK/1 as the count clock for MTU1.

Table 19.12 TIORL (MTU0)

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Description               |                                                                                                |
|--------|--------|--------|--------|---------------------------|------------------------------------------------------------------------------------------------|
| IOD[3] | IOD[2] | IOD[1] | IOD[0] | MTU0.TGRD Function        | MTIOC0D Pin Function                                                                           |
| 0      | 0      | 0      | 0      | Output compare register*1 | Output prohibited                                                                              |
| 0      | 0      | 0      | 1      | _                         | Initial output is low. Low output at compare match.                                            |
| 0      | 0      | 1      | 0      | _                         | Initial output is low.<br>High output at compare match.                                        |
| 0      | 0      | 1      | 1      | _                         | Initial output is low. Toggle output at compare match.                                         |
| 0      | 1      | 0      | 0      | _                         | Output prohibited                                                                              |
| 0      | 1      | 0      | 1      | _                         | Initial output is high. Low output at compare match.                                           |
| 0      | 1      | 1      | 0      | _                         | Initial output is high. High output at compare match.                                          |
| 0      | 1      | 1      | 1      | _                         | Initial output is high. Toggle output at compare match.                                        |
| 1      | 0      | 0      | 0      | Input capture register*1  | Input capture at rising edge.                                                                  |
| 1      | 0      | 0      | 1      | _                         | Input capture at falling edge.                                                                 |
| 1      | 0      | 1      | х      | _                         | Input capture at both edges.                                                                   |
| 1      | 1      | Х      | Х      | _                         | Capture input source is count clock in MTU1. Input capture at MTU1.TCNT up-count/down-count.*2 |

x: Don't care

Table 19.13 TIOR (MTU1)

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Description             |                                                                       |
|--------|--------|--------|--------|-------------------------|-----------------------------------------------------------------------|
| IOB[3] | IOB[2] | IOB[1] | IOB[0] | MTU1.TGRB Function      | MTIOC1B Pin Function                                                  |
| 0      | 0      | 0      | 0      | Output compare register | Output prohibited                                                     |
| 0      | 0      | 0      | 1      | _                       | Initial output is low. Low output at compare match.                   |
| 0      | 0      | 1      | 0      | _                       | Initial output is low. High output at compare match.                  |
| 0      | 0      | 1      | 1      | _                       | Initial output is low. Toggle output at compare match.                |
| 0      | 1      | 0      | 0      | _                       | Output prohibited                                                     |
| 0      | 1      | 0      | 1      | _                       | Initial output is high. Low output at compare match.                  |
| 0      | 1      | 1      | 0      | _                       | Initial output is high. High output at compare match.                 |
| 0      | 1      | 1      | 1      | _                       | Initial output is high. Toggle output at compare match.               |
| 1      | 0      | 0      | 0      | Input capture register  | Input capture at rising edge.                                         |
| 1      | 0      | 0      | 1      | _                       | Input capture at falling edge.                                        |
| 1      | 0      | 1      | Х      | _                       | Input capture at both edges.                                          |
| 1      | 1      | х      | х      | _                       | Input capture at generation of MTU0.TGRC compare match/input capture. |

x: Don't care



Note 1. When the MTU0.TMDR.BFB is set to 1 and the MTU0.TGRD register is used as a buffer register, this setting is invalid and input capture/output compare is not generated.

Note 2. When PCLK/1 is selected as the count clock for MTU1, MTU0 input capture is not generated. Do not select PCLK/1 as the count clock for MTU1.

Table 19.14 TIOR (MTU2)

| Bit 7  | Bit 6  | Bit 5  | Bit 4  | Description             |                                                         |
|--------|--------|--------|--------|-------------------------|---------------------------------------------------------|
| IOB[3] | IOB[2] | IOB[1] | IOB[0] | MTU2.TGRB Function      | MTIOC2B Pin Function                                    |
| 0      | 0      | 0      | 0      | Output compare register | Output prohibited                                       |
| 0      | 0      | 0      | 1      | _                       | Initial output is low. Low output at compare match.     |
| 0      | 0      | 1      | 0      | _                       | Initial output is low. High output at compare match.    |
| 0      | 0      | 1      | 1      | _                       | Initial output is low. Toggle output at compare match.  |
| 0      | 1      | 0      | 0      | _                       | Output prohibited                                       |
| 0      | 1      | 0      | 1      | _                       | Initial output is high. Low output at compare match.    |
| 0      | 1      | 1      | 0      | _                       | Initial output is high. High output at compare match.   |
| 0      | 1      | 1      | 1      | _                       | Initial output is high. Toggle output at compare match. |
| 1      | х      | 0      | 0      | Input capture register  | Input capture at rising edge.                           |
| 1      | х      | 0      | 1      | _                       | Input capture at falling edge.                          |
| 1      | х      | 1      | х      | _                       | Input capture at both edges.                            |

x: Don't care

Table 19.15 TIORH (MTU0)

| Bit 3  | Bit 2  | Bit 1  | Bit 0  | Description             |                                                                                                 |
|--------|--------|--------|--------|-------------------------|-------------------------------------------------------------------------------------------------|
| IOA[3] | IOA[2] | IOA[1] | IOA[0] | MTU0.TGRA Function      | MTIOC0A Pin Function                                                                            |
| 0      | 0      | 0      | 0      | Output compare register | Output prohibited                                                                               |
| 0      | 0      | 0      | 1      | _                       | Initial output is low. Low output at compare match.                                             |
| 0      | 0      | 1      | 0      | _                       | Initial output is low. High output at compare match.                                            |
| 0      | 0      | 1      | 1      | _                       | Initial output is low. Toggle output at compare match.                                          |
| 0      | 1      | 0      | 0      |                         | Output prohibited                                                                               |
| 0      | 1      | 0      | 1      | _                       | Initial output is high. Low output at compare match.                                            |
| 0      | 1      | 1      | 0      | _                       | Initial output is high. High output at compare match.                                           |
| 0      | 1      | 1      | 1      | _                       | Initial output is high. Toggle output at compare match.                                         |
| 1      | 0      | 0      | 0      | Input capture register  | Input capture at rising edge.                                                                   |
| 1      | 0      | 0      | 1      | _                       | Input capture at falling edge.                                                                  |
| 1      | 0      | 1      | Х      | _                       | Input capture at both edges.                                                                    |
| 1      | 1      | х      | х      | _                       | Capture input source is count clock in MTU1.  Input capture at MTU1.TCNT up-count/down-count.*1 |

x: Don't care

Note 1. When PCLK/1 is selected as the count clock for MTU1, MTU0 input capture is not generated. Do not select PCLK/1 as the count clock for MTU1.

Table 19.16 TIORL (MTU0)

| Bit 3  | Bit 2  | Bit 1  | Bit 0  | Description               |                                                                                                |
|--------|--------|--------|--------|---------------------------|------------------------------------------------------------------------------------------------|
| IOC[3] | IOC[2] | IOC[1] | IOC[0] | MTU0.TGRC Function        | MTIOC0C Pin Function                                                                           |
| 0      | 0      | 0      | 0      | Output compare register*1 | Output prohibited                                                                              |
| 0      | 0      | 0      | 1      | _                         | Initial output is low. Low output at compare match.                                            |
| 0      | 0      | 1      | 0      | _                         | Initial output is low.<br>High output at compare match.                                        |
| 0      | 0      | 1      | 1      | _                         | Initial output is low. Toggle output at compare match.                                         |
| 0      | 1      | 0      | 0      | _                         | Output prohibited                                                                              |
| 0      | 1      | 0      | 1      | _                         | Initial output is high. Low output at compare match.                                           |
| 0      | 1      | 1      | 0      | _                         | Initial output is high. High output at compare match.                                          |
| 0      | 1      | 1      | 1      | _                         | Initial output is high. Toggle output at compare match.                                        |
| 1      | 0      | 0      | 0      | Input capture register*1  | Input capture at rising edge.                                                                  |
| 1      | 0      | 0      | 1      | _                         | Input capture at falling edge.                                                                 |
| 1      | 0      | 1      | Х      | _                         | Input capture at both edges.                                                                   |
| 1      | 1      | Х      | х      | _                         | Capture input source is count clock in MTU1. Input capture at MTU1.TCNT up-count/down-count.*2 |

x: Don't care

Table 19.17 TIOR (MTU1)

| Bit 3  | Bit 2  | Bit 1  | Bit 0  | Description             |                                                                       |
|--------|--------|--------|--------|-------------------------|-----------------------------------------------------------------------|
| IOA[3] | IOA[2] | IOA[1] | IOA[0] | MTU1.TGRA Function      | MTIOC1A Pin Function                                                  |
| 0      | 0      | 0      | 0      | Output compare register | Output prohibited                                                     |
| 0      | 0      | 0      | 1      | _                       | Initial output is low. Low output at compare match.                   |
| 0      | 0      | 1      | 0      | _                       | Initial output is low. High output at compare match.                  |
| 0      | 0      | 1      | 1      | _                       | Initial output is low. Toggle output at compare match.                |
| 0      | 1      | 0      | 0      | <del>_</del>            | Output prohibited                                                     |
| 0      | 1      | 0      | 1      | _                       | Initial output is high. Low output at compare match.                  |
| 0      | 1      | 1      | 0      | _                       | Initial output is high. High output at compare match.                 |
| 0      | 1      | 1      | 1      | _                       | Initial output is high. Toggle output at compare match.               |
| 1      | 0      | 0      | 0      | Input capture register  | Input capture at rising edge.                                         |
| 1      | 0      | 0      | 1      | <del>_</del>            | Input capture at falling edge.                                        |
| 1      | 0      | 1      | х      | <del>_</del>            | Input capture at both edges.                                          |
| 1      | 1      | х      | х      | _                       | Input capture at generation of MTU0.TGRA compare match/input capture. |

x: Don't care



Note 1. When the MTU0.TMDR.BFA bit is set to 1 and the MTU0.TGRC register is used as a buffer register, this setting is invalid and input capture/output compare is not generated.

Note 2. When PCLK/1 is selected as the count clock for MTU1, MTU0 input capture is not generated. Do not select PCLK/1 as the count clock for MTU1.

Table 19.18 TIOR (MTU2)

| Bit 3  | Bit 2  | Bit 1  | Bit 0  | Description             |                                                         |
|--------|--------|--------|--------|-------------------------|---------------------------------------------------------|
| IOA[3] | IOA[2] | IOA[1] | IOA[0] | MTU2.TGRA Function      | MTIOC2A Pin Function                                    |
| 0      | 0      | 0      | 0      | Output compare register | Output prohibited                                       |
| 0      | 0      | 0      | 1      | _                       | Initial output is low. Low output at compare match.     |
| 0      | 0      | 1      | 0      | _                       | Initial output is low. High output at compare match.    |
| 0      | 0      | 1      | 1      | _                       | Initial output is low. Toggle output at compare match.  |
| 0      | 1      | 0      | 0      | <del>_</del>            | Output prohibited                                       |
| 0      | 1      | 0      | 1      | _                       | Initial output is high. Low output at compare match.    |
| 0      | 1      | 1      | 0      | _                       | Initial output is high. High output at compare match.   |
| 0      | 1      | 1      | 1      | _                       | Initial output is high. Toggle output at compare match. |
| 1      | х      | 0      | 0      | Input capture register  | Input capture at rising edge.                           |
| 1      | х      | 0      | 1      | _                       | Input capture at falling edge.                          |
| 1      | Х      | 1      | х      | _                       | Input capture at both edges.                            |

x: Don't care

Table 19.19 TIORU, TIORV, and TIORW (MTU5)

| Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  | Description                                    |                                                           |
|--------|--------|--------|--------|--------|------------------------------------------------|-----------------------------------------------------------|
| IOC[4] | IOC[3] | IOC[2] | IOC[1] | IOC[0] | MTU5.TGRU,<br>MTU5.TGRV,<br>MTU5.TGRW Function | MTIC5U, MTIC5V, MTIC5W Pin Function                       |
| 0      | 0      | 0      | 0      | 0      | Compare match register                         | Compare match                                             |
| 0      | 0      | 0      | 0      | 1      | -                                              | Setting prohibited                                        |
| 0      | 0      | 0      | 1      | х      | -                                              | Setting prohibited                                        |
| 0      | 0      | 1      | х      | х      | -                                              | Setting prohibited                                        |
| 0      | 1      | х      | х      | х      | -                                              | Setting prohibited                                        |
| 1      | 0      | 0      | 0      | 0      | Input capture register*1                       | Setting prohibited                                        |
| 1      | 0      | 0      | 0      | 1      | -                                              | Input capture at rising edge.                             |
| 1      | 0      | 0      | 1      | 0      | -                                              | Input capture at falling edge.                            |
| 1      | 0      | 0      | 1      | 1      | -                                              | Input capture at both edges.                              |
| 1      | 0      | 1      | х      | х      | -                                              | Setting prohibited                                        |
| 1      | 1      | 0      | 0      | 0      | -                                              | Setting prohibited                                        |
| 1      | 1      | 0      | 0      | 1      | -                                              | Measurement of low pulse width of external input signal.  |
| 1      | 1      | 0      | 1      | 0      | -                                              | Measurement of low pulse width of external input signal.  |
| 1      | 1      | 0      | 1      | 1      | <del>-</del>                                   | Measurement of low pulse width of external input signal.  |
| 1      | 1      | 1      | 0      | 0      | -                                              | Setting prohibited                                        |
| 1      | 1      | 1      | 0      | 1      | -                                              | Measurement of high pulse width of external input signal. |
| 1      | 1      | 1      | 1      | 0      | -                                              | Measurement of high pulse width of external input signal. |
| 1      | 1      | 1      | 1      | 1      | -                                              | Measurement of high pulse width of external input signal. |

x: Don't care

Note 1. Set the IOC[4:0] bits to 19h, 1Ah, 1Bh, 1Dh, 1Eh, or 1Fh only when using external pulse width measurement. For details, refer to section 19.3.7, External Pulse Width Measurement.

# 19.2.4 Timer Compare Match Clear Register (TCNTCMPCLR)

Address(es): MTU5.TCNTCMPCLR 0008 88B6h



| Bit      | Symbol   | Bit Name              | Description                                                                                                                                                                                                       | R/W |
|----------|----------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | CMPCLR5W | TCNT Compare Clear 5W | O: Disables MTU5.TCNTW to be cleared to 0000h at MTU5.TCNTW and MTU5.TGRW compare match or input capture  1: Enables MTU5.TCNTW to be cleared to 0000h at MTU5.TCNTW and MTU5.TGRW compare match or input capture | R/W |
| b1       | CMPCLR5V | TCNT Compare Clear 5V | O: Disables MTU5.TCNTV to be cleared to 0000h at MTU5.TCNTV and MTU5.TGRV compare match or input capture  1: Enables MTU5.TCNTV to be cleared to 0000h at MTU5.TCNTV and MTU5.TGRV compare match or input capture | R/W |
| b2       | CMPCLR5U | TCNT Compare Clear 5U | O: Disables MTU5.TCNTU to be cleared to 0000h at MTU5.TCNTU and MTU5.TGRU compare match or input capture  1: Enables MTU5.TCNTU to be cleared to 0000h at MTU5.TCNTU and MTU5.TGRU compare match or input capture | R/W |
| b7 to b3 | _        | Reserved              | These bits are read as 0. The write value should be 0.                                                                                                                                                            | R/W |

The TCNTCMPCLR register specifies requests to clear counters MTU5.TCNTU, MTU5.TCNTV, and MTU5.TCNTW.

## 19.2.5 Timer Interrupt Enable Register (TIER)

#### • MTU0.TIER

Address(es): MTU0.TIER 0008 8704h



## • MTU1.TIER, MTU2.TIER

Address(es): MTU1.TIER 0008 8784h, MTU2.TIER 0008 8804h



| Bit | Symbol | Bit Name                           | Description                                                                                              | R/W |
|-----|--------|------------------------------------|----------------------------------------------------------------------------------------------------------|-----|
| b0  | TGIEA  | TGR Interrupt Enable A             | 0: Interrupt requests (TGIA) disabled 1: Interrupt requests (TGIA) enabled                               | R/W |
| b1  | TGIEB  | TGR Interrupt Enable B             | 0: Interrupt requests (TGIB) disabled 1: Interrupt requests (TGIB) enabled                               | R/W |
| b2  | TGIEC  | TGR Interrupt Enable C             | 0: Interrupt requests (TGIC) disabled 1: Interrupt requests (TGIC) enabled                               | R/W |
| b3  | TGIED  | TGR Interrupt Enable D             | 0: Interrupt requests (TGID) disabled 1: Interrupt requests (TGID) enabled                               | R/W |
| b4  | TCIEV  | Overflow Interrupt Enable          | 0: Interrupt requests (TCIV) disabled 1: Interrupt requests (TCIV) enabled                               | R/W |
| b5  | TCIEU  | Underflow Interrupt Enable         | 0: Interrupt requests (TCIU) disabled 1: Interrupt requests (TCIU) enabled                               | R/W |
| b6  | _      | Reserved                           | This bit is read as 0. The write value should be 0.                                                      | R/W |
| b7  | TTGE   | A/D Converter Start Request Enable | O: A/D converter start request generation disabled     1: A/D converter start request generation enabled | R/W |

The MTU has a total of five TIER registers, two each for MTU0 and one each for MTU1, MTU2, and MTU5. The TIER register enables or disables interrupt requests in each channel.

## TGIEA and TGIEB Bits (TGR Interrupt Enable A and B)

Each bit enables or disables interrupt requests (TGIm) (m = A, B).

## TGIEC and TGIED Bits (TGR Interrupt Enable C and D)

Each bit enables or disables interrupt requests (TGIm) in MTU0 (m = C, D).

In MTU1 and MTU2, these bits are reserved. They are read as 0. The write value should be 0.

#### **TCIEV Bit (Overflow Interrupt Enable)**

This bit enables or disables interrupt requests (TCIV).

## **TCIEU Bit (Underflow Interrupt Enable)**

This bit enables or disables interrupt requests (TCIU) in MTU1 and MTU2.



In MTU0, this bit is reserved. It is read as 0. The write value should be 0.

## TTGE Bit (A/D Converter Start Request Enable)

This bit enables or disables generation of A/D converter start requests by the TGRA input capture/compare match.

#### • MTU0.TIER2

Address(es): MTU0.TIER2 0008 8724h



| Bit      | Symbol | Bit Name               | Description                                                              | R/W |
|----------|--------|------------------------|--------------------------------------------------------------------------|-----|
| b0       | TGIEE  | TGR Interrupt Enable E | Interrupt requests (TGIE) disabled     Interrupt requests (TGIE) enabled | R/W |
| b1       | TGIEF  | TGR Interrupt Enable F | Interrupt requests (TGIF) disabled     Interrupt requests (TGIF) enabled | R/W |
| b7 to b2 | _      | Reserved               | These bits are read as 0. The write value should be 0.                   | R/W |

## TGIEE and TGIEF Bits (TGR Interrupt Enable E and F)

Each bit enables or disables interrupt requests by compare match between the MTU0.TCNT counter and the MTU0.TGRm register (m = E, F).

## • MTU5.TIER

Address(es): MTU5.TIER 0008 88B2h



| Bit      | Symbol | Bit Name                | Description                                                            | R/W |
|----------|--------|-------------------------|------------------------------------------------------------------------|-----|
| b0       | TGIE5W | TGR Interrupt Enable 5W | Interrupt requests TGI5W disabled     Interrupt requests TGI5W enabled | R/W |
| b1       | TGIE5V | TGR Interrupt Enable 5V | Interrupt requests TGI5V disabled     Interrupt requests TGI5V enabled | R/W |
| b2       | TGIE5U | TGR Interrupt Enable 5U | Interrupt requests TGI5U disabled     Interrupt requests TGI5U enabled | R/W |
| b7 to b3 | _      | Reserved                | These bits are read as 0. The write value should be 0.                 | R/W |

## TGIE5W, TGIE5V, and TGIE5U Bits (TGR Interrupt Enable 5m)

Each bit enables or disables interrupt requests (TGI5m) (m = W, V, U).

# 19.2.6 Timer Status Register (TSR)

Address(es): MTU0.TSR 0008 8705h, MTU1.TSR 0008 8785h, MTU2.TSR 0008 8805h



x: Undefined

| Bit      | Symbol | Bit Name             | Description                                                    | R/W |
|----------|--------|----------------------|----------------------------------------------------------------|-----|
| b5 to b0 | _      | Reserved             | These bits are read as undefined. The write value should be 1. | R/W |
| b6       |        | Reserved             | This bit is read as 1. The write value should be 1.            | R/W |
| b7       | TCFD   | Count Direction Flag | 0: TCNT counts down 1: TCNT counts up                          | R   |

The MTU has a total of three TSR registers, one each for MTU0 to MTU2.

The TSR register indicates the status of each channel.

## **TCFD Flag (Count Direction Flag)**

Status flag that shows the direction in which the TCNT counter counts in MTU1 to MTU2.

In MTU0, this bit is reserved. It is read as 1. The write value should be 1.

## 19.2.7 Timer Buffer Operation Transfer Mode Register (TBTM)

Address(es): MTU0.TBTM 0008 8726h



| Bit      | Symbol | Bit Name        | Description                                                                                                                                                                    | R/W |
|----------|--------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | TTSA   | Timing Select A | When compare match A occurs in each channel, data is transferred from TGRC to TGRA     When TCNT is cleared in each channel, data is transferred from TGRC to TGRA             | R/W |
| b1       | TTSB   | Timing Select B | When compare match B occurs in each channel, data is transferred from TGRD to TGRB     When TCNT is cleared in each channel, data is transferred from TGRD to TGRB             | R/W |
| b2       | TTSE   | Timing Select E | O: When compare match E occurs in MTU0, data is transferred from MTU0.TGRF to MTU0.TGRE  1: When MTU0.TCNT is cleared in MTU0, data is transferred from MTU0.TGRF to MTU0.TGRE | R/W |
| b7 to b3 | _      | Reserved        | These bits are read as 0. The write value should be 0.                                                                                                                         | R/W |

The MTU has one TBTM register for MTU0.

The TBTM register specifies the timing for transferring data from the buffer register to the timer general register in PWM mode.

#### TTSA Bit (Timing Select A)

This bit specifies the timing for transferring data from the TGRC register to the TGRA register in each channel when they are used together for buffer operation. When a channel is not set to PWM mode, do not set the TTSA bit in the channel to 1.

#### TTSB Bit (Timing Select B)

This bit specifies the timing for transferring data from the TGRD register to the TGRB register in each channel when they are used together for buffer operation. When a channel is not set to PWM mode, do not set the TTSB bit in the channel to 1.

#### TTSE Bit (Timing Select E)

This bit specifies the timing for transferring data from the MTU0.TGRF register to the MTU0.TGRE register when they are used together for buffer operation. When MTU0 is not set to PWM mode, do not set the TTSE bit to 1.

## 19.2.8 Timer Input Capture Control Register (TICCR)

Address(es): MTU1.TICCR 0008 8790h



| Bit      | Symbol | Bit Name             | Description                                                                                                                                       | R/W |
|----------|--------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | I1AE   | Input Capture Enable | Does not include the MTIOC1A pin in the MTU2.TGRA input capture conditions     Includes the MTIOC1A pin in the MTU2.TGRA input capture conditions | R/W |
| b1       | I1BE   | Input Capture Enable | Does not include the MTIOC1B pin in the MTU2.TGRB input capture conditions     Includes the MTIOC1B pin in the MTU2.TGRB input capture conditions | R/W |
| b2       | I2AE   | Input Capture Enable | Does not include the MTIOC2A pin in the MTU1.TGRA input capture conditions     Includes the MTIOC2A pin in the MTU1.TGRA input capture conditions | R/W |
| b3       | I2BE   | Input Capture Enable | Does not include the MTIOC2B pin in the MTU1.TGRB input capture conditions     Includes the MTIOC2B pin in the MTU1.TGRB input capture conditions | R/W |
| b7 to b4 | _      | Reserved             | These bits are read as 0. The write value should be 0.                                                                                            | R/W |

The MTU has one TICCR register for MTU1.

The TICCR register specifies input capture conditions when counters MTU1.TCNT and MTU2.TCNT are cascaded.

## 19.2.9 Timer Counter (TCNT)

Address(es): MTU0.TCNT 0008 8706h, MTU1.TCNT 0008 8786h, MTU2.TCNT 0008 8806h, MTU5.TCNTU 0008 8880h, MTU5.TCNTV 0008 8890h, MTU5.TCNTW 0008 88A0h



Note: The TCNT counters must not be accessed in 8-bit units; they should be accessed in 16-bit units.

The MTU has a total of six TCNT counters, one each for MTU0 to MTU2 and three (MTU5.TCNTU, TCNTV, and TCNTW) for MTU5. TCNT is a readable/writable counter.

## 19.2.10 Timer General Register (TGR)

Address(es): MTU0.TGRA 0008 8708h, MTU0.TGRB 0008 870Ah, MTU0.TGRC 0008 870Ch, MTU0.TGRD 0008 870Eh, MTU0.TGRE 0008 8720h, MTU0.TGRF 0008 8722h, MTU1.TGRA 0008 8788h, MTU1.TGRB 0008 878Ah, MTU2.TGRA 0008 8808h, MTU2.TGRB 0008 880Ah, MTU5.TGRU 0008 8882h, MTU5.TGRV 0008 8892h, MTU5.TGRV 0008 8842h



Note: The TGR registers must not be accessed in 8-bit units; they should be accessed in 16-bit units.

The MTU has a total of 13 TGR registers, six for MTU0, two each for MTU1 and MTU2, and three for MTU5. Registers TGRA, TGRB, TGRC, and TGRD function as either output compare or input capture registers. Registers TGRC and TGRD for MTU0 can also be designated for operation as buffer registers. TGR buffer register combinations are TGRA and TGRC, and TGRB and TGRD.

Registers MTU0.TGRE and MTU0.TGRF function as compare registers. When the MTU0.TCNT count matches the MTU0.TGRE register value, an A/D converter start request can be issued. The TGRF register can also be designated for operation as a buffer register. TGR buffer register combination is TGRE and TGRF.

Registers MTU5.TGRU, MTU5.TGRV, and MTU5.TGRW function as compare match, input capture, or external pulse width measurement registers.

## 19.2.11 Timer Start Registers (TSTR)

## • MTU.TSTR (MTU0 to MTU2)

Address(es): MTU.TSTR 0008 8680h



| Bit      | Symbol | Bit Name        | Description                                                            | R/W |
|----------|--------|-----------------|------------------------------------------------------------------------|-----|
| b0       | CST0   | Counter Start 0 | MTU0.TCNT performs count stop     MTU0.TCNT performs count operation   | R/W |
| b1       | CST1   | Counter Start 1 | 0: MTU1.TCNT performs count stop 1: MTU1.TCNT performs count operation | R/W |
| b2       | CST2   | Counter Start 2 | MTU2.TCNT performs count stop     MTU2.TCNT performs count operation   | R/W |
| b7 to b3 | _      | Reserved        | These bits are read as 0. The write value should be 0.                 | R/W |

The TSTR registers start or stop the TCNT operation in MTU0 to MTU2.

Before setting the operating mode in the TMDR register or setting the TCNT count clock in the TCR register, be sure to stop the TCNT counter.

## CSTn Bits (Counter Start n) (n = 0 to 2)

Each bit starts or stops the TCNT counter in the corresponding channel.

If 0 is written to the CSTn bit during operation with the MTIOC pin designated for output, the counter stops but the output compare signal level from the MTIOC pin is retained. If the TIOR register is written to while the CSTn bit is 0, the pin output level will be changed to the specified initial output value.

## • MTU5.TSTR (MTU5)

Address(es): MTU5.TSTR 0008 88B4h



| Bit      | Symbol | Bit Name         | Description                                                                   | R/W |
|----------|--------|------------------|-------------------------------------------------------------------------------|-----|
| b0       | CSTW5  | Counter Start W5 | MTU5.TCNTW count operation is stopped     HTU5.TCNTW performs count operation | R/W |
| b1       | CSTV5  | Counter Start V5 | MTU5.TCNTV count operation is stopped     HTU5.TCNTV performs count operation | R/W |
| b2       | CSTU5  | Counter Start U5 | MTU5.TCNTU count operation is stopped     HTU5.TCNTU performs count operation | R/W |
| b7 to b3 | _      | Reserved         | These bits are read as 0. The write value should be 0.                        | R/W |

## 19.2.12 Timer Synchronous Registers (TSYR)

Address(es): MTU.TSYR 0008 8681h



| Bit      | Symbol | Bit Name                      | Description                                                                                                                                                                                         | R/W |
|----------|--------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | SYNC0  | Timer Synchronous Operation 0 | O: MTU0.TCNT operates independently (TCNT setting/clearing is not related to other channels)  1: MTU0.TCNT performs synchronous operation. TCNT synchronous setting/synchronous clearing is enabled | R/W |
| b1       | SYNC1  | Timer Synchronous Operation 1 | O: MTU1.TCNT operates independently (TCNT setting/clearing is not related to other channels)  1: MTU1.TCNT performs synchronous operation. TCNT synchronous setting/synchronous clearing is enabled | R/W |
| b2       | SYNC2  | Timer Synchronous Operation 2 | O: MTU2.TCNT operates independently (TCNT setting/clearing is not related to other channels)  1: MTU2.TCNT performs synchronous operation. TCNT synchronous setting/synchronous clearing is enabled | R/W |
| b7 to b3 | _      | Reserved                      | These bits are read as 0. The write value should be 0.                                                                                                                                              | R/W |

The TSYR registers select independent operation or synchronous operation of the TCNT counter in MTU0 to MTU2. A channel performs synchronous operation when the corresponding bit in the TSYR register is set to 1.

## SYNCn Bits (Timer Synchronous n Operation) (n = 0 to 2)

Each bit selects whether operation is independent of or synchronized with other channels.

When synchronous operation is selected, the TCNT synchronous setting of multiple channels and synchronous clearing by counter clearing on another channel are possible.

To set synchronous operation, the SYNCn bits for at least two channels must be set to 1. To set synchronous clearing, in addition to the SYNCn bit, the TCNT clearing source must also be set the TCR.CCLR[2:0] bits.

## 19.2.13 Noise Filter Control Registers (NFCR)

• MTU0.NFCR, MTU1.NFCR, MTU2.NFCR

Address(es): MTU0.NFCR 0008 8690h, MTU1.NFCR 0008 8691h, MTU2.NFCR 0008 8692h



| Bit    | Symbol    | Bit Name                  | Description                                                                                            | R/W   |
|--------|-----------|---------------------------|--------------------------------------------------------------------------------------------------------|-------|
| b0     | NFAEN     | Noise Filter A Enable     | The noise filter for the MTIOCnA pin is disabled     The noise filter for the MTIOCnA pin is enabled   | R/W   |
| b1     | NFBEN     | Noise Filter B Enable     | 0: The noise filter for the MTIOCnB pin is disabled 1: The noise filter for the MTIOCnB pin is enabled | R/W   |
| b2     | NFCEN     | Noise Filter C Enable     | The noise filter for the MTIOCnC pin is disabled     The noise filter for the MTIOCnC pin is enabled   | R/W*1 |
| b3     | NFDEN     | Noise Filter D Enable     | The noise filter for the MTIOCnD pin is disabled     The noise filter for the MTIOCnD pin is enabled   | R/W*1 |
| b5, b4 | NFCS[1:0] | Noise Filter Clock Select | b5 b4 0 0: PCLK/1 0 1: PCLK/8 1 0: PCLK/32 1 1: The clock source for counting is the external clock    | R/W   |
| b7, b6 | _         | Reserved                  | These bits are read as 0. The write value should be 0.                                                 | R/W   |

Note 1. These bits are reserved in the NFCR for MTU1 and MTU2. These bits are read as 0, and writing to them is not possible.

The MTUn.NFCR registers (n = 0 to 2) enable and disable the noise filters for the MTIOCnm (n = 0 to 2; m = A to D) pins and sets the sampling clocks for the noise filters.

#### NFAEN Bit (Noise Filter A Enable)

This bit disables or enables the noise filter for input from the MTIOCnA pin. Since unexpected edges may be internally generated when the value of the NFAEN bit is changed, select the output compare function in the timer I/O control register and set the TMDR.MD[3:0] bits to a value other than that for normal mode (0000b) before changing the value.

#### NFBEN Bit (Noise Filter B Enable)

This bit disables or enables the noise filter for input from the MTIOCnB pin. Since unexpected edges may be internally generated when the value of the NFBEN bit is changed, select the output compare function in the timer I/O control register and set the TMDR.MD[3:0] bits to a value other than that for normal mode (0000b) before changing the value.

## **NFCEN Bit (Noise Filter C Enable)**

This bit disables or enables the noise filter for input from the MTIOCnC pin. Since unexpected edges may be internally generated when the value of the NFCEN bit is changed, select the output compare function in the timer I/O control register and set the TMDR.MD[3:0] bits to a value other than that for normal mode (0000b) before changing the value.

## NFDEN Bit (Noise Filter D Enable)

This bit disables or enables the noise filter for input from the MTIOCnD pin. Since unexpected edges may be internally generated when the value of the NFDEN bit is changed, select the output compare function in the timer I/O control register and set the TMDR.MD[3:0] bits to a value other than that for normal mode (0000b) before changing the value.



#### NFCS[1:0] Bits (Noise Filter Clock Select)

These bits set the sampling interval for the noise filters. When setting the NFCS[1:0] bits, wait for two cycles of the selected sampling interval before setting the input-capture function. When the NFCS[1:0] bits are set to 11b, selecting the external clock as the source to drive counting, wait for two cycles of the external clock before setting the input-capture function.

#### MTU5.NFCR

Address(es): MTU5.NFCR 0008 8695h



| Bit    | Symbol    | Bit Name                  | Description                                                                                                                      | R/W |
|--------|-----------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----|
| b0     | NFUEN     | Noise Filter U Enable     | 0: The noise filter for the MTIC5U pin is disabled. 1: The noise filter for the MTIC5U pin is enabled.                           | R/W |
| b1     | NFVEN     | Noise Filter V Enable     | <ul><li>0: The noise filter for the MTIC5V pin is disabled.</li><li>1: The noise filter for the MTIC5V pin is enabled.</li></ul> | R/W |
| b2     | NFWEN     | Noise Filter W Enable     | O: The noise filter for the MTIC5W pin is disabled. The noise filter for the MTIC5W pin is enabled.                              | R/W |
| b3     | _         | Reserved                  | This bit is read as 0. The write value should be 0.                                                                              | R/W |
| b5, b4 | NFCS[1:0] | Noise Filter Clock Select | b5 b4 0 0: PCLK/1 0 1: PCLK/8 1 0: PCLK/32 1 1: The clock source for counting is the external clock.                             | R/W |
| b7, b6 |           | Reserved                  | These bits are read as 0. The write value should be 0.                                                                           | R/W |

The MTU5.NFCR register is 8-bit readable and writable register. This register controls enabling and disabling of the noise filters for the MTIC5m (m = U, V, W) pins and sets the sampling clock for the noise filters.

#### **NFUEN Bit (Noise Filter U Enable)**

This bit disables or enables the noise filter for input from the MTIC5U pin. Since unexpected edges may be internally generated when the value of the NFUEN bit is changed, select the compare-match function in the timer I/O control register before changing the value.

#### **NFVEN Bit (Noise Filter V Enable)**

This bit disables or enables the noise filter for input from the MTIC5V pin. Since unexpected edges may be internally generated when the value of the NFVEN bit is changed, select the compare-match function in the timer I/O control register before changing the value.

#### **NFWEN Bit (Noise Filter W Enable)**

This bit disables or enables the noise filter for input from the MTIC5W pin. Since unexpected edges may be internally generated when the value of the NFWEN bit is changed, select the compare-match function in the timer I/O control register before changing the value.

## NFCS[1:0] Bits (Noise Filter Clock Select)

These bits set the sampling interval for the noise filters. When setting the NFCS[1:0] bits, wait for two cycles of the selected sampling interval before setting the input-capture function.



## 19.2.14 Bus Master Interface

The timer counters (TCNT) and timer general registers (TGR) are 16-bit registers. A 16-bit data bus to the bus master enables 16-bit read/write access. 8-bit read/write is not allowed. Access the registers in 16-bit units.

All registers other than the above registers are 8-bit registers, so read/write access should be performed in 8-bit units.



## 19.3 Operation

#### 19.3.1 Basic Functions

Each channel has the TCNT counter and the TGR register. The TCNT counter performs up-counting, and is also capable of free-running operation, periodic counting, and external event counting.

Each TGR register can be used as an input capture register or an output compare register.

## (1) Counter Operation

When one of bits CST0 to CST2 in the TSTR register or bits CSTU5, CSTV5, and CSTW5 in the MTU5.TSTR register is set to 1, the TCNT counter for the corresponding channel begins counting. The TCNT counter can operate as a free-running counter, periodic counter, for example.

#### (a) Example of Count Operation Setting Procedure

Figure 19.2 shows an example of the count operation setting procedure.



Figure 19.2 Example of Counter Operation Setting Procedure

#### (b) Free-Running Count Operation and Periodic Count Operation

Immediately after a reset, the MTU's TCNT counters are all designated as free-running counters. When the relevant CSTn bit in the TSTR register is set to 1, the corresponding TCNT counter starts up-count operation as a free-running counter. When TCNT overflows (from FFFFh to 0000h), the MTU requests an interrupt if the corresponding TCIEV bit in the TIER register is 1. After an overflow, the TCNT counter starts counting up again from 0000h. Figure 19.3 illustrates free-running counter operation.



Figure 19.3 Free-Running Counter Operation

When compare match is selected as the TCNT clearing source, the TCNT counter for the relevant channel performs periodic count operation. The TGR register for setting the cycle is designated as an output compare register, and counter clearing by compare match is selected by means of the TCR.CCLR[2:0] bits. After the settings have been made, the TCNT counter starts up-count operation as a periodic counter when the corresponding bit in the TSTR register is set to 1. When the count matches the value in the TGR register, the TCNT counter is set to 0000h.

If the value of the corresponding TIER.TGIE bit is 1 at this point, the MTU requests an interrupt. After a compare match, the TCNT counter starts counting up again from 0000h.

Figure 19.4 illustrates periodic counter operation.



Figure 19.4 Periodic Counter Operation

## (2) Waveform Output by Compare Match

The MTU can output low or high or toggle output from the corresponding output pin using compare match.

# (a) Example of Procedure for Setting Waveform Output by Compare Match

Figure 19.5 shows an example of the procedure for setting waveform output by compare match.



Figure 19.5 Example of Procedure for Setting Waveform Output by Compare Match

#### (b) Examples of Waveform Output Operation

Figure 19.6 shows an example of low output and high output.

In this example, the TCNT counter has been designated as a free-running counter, and settings have been made so that high is output by compare match A and low is output by compare match B. When the pin level is the same as the specified level, the pin level does not change.



Figure 19.6 Example of Low Output and High Output Operation

Figure 19.7 shows an example of toggle output.

In this example, the TCNT counter has been designated as a periodic counter (with counter clearing on compare match B), and settings have been made so that the output is toggled by both compare match A and compare match B.



Figure 19.7 Example of Toggle Output Operation

# (3) Input Capture Function

The TCNT value can be transferred to the TGR register on detection of the input edge of the MTIOCnm (n = 0 to 2; m = A to D) pin and MTIC5m (m = W, V, U) pin.

The rising edge, falling edge, or both edges can be selected as the detection edge. For MTU0 and MTU1, another channel's count clock or compare match signal can also be specified as the input capture source.

Note: When another channel's count clock is used as the input capture input for MTU0 and MTU1, PCLK/1 should not be selected as the count clock used for input capture input. Input capture will not be generated if PCLK/1 is selected.

#### (a) Example of Input Capture Operation Setting Procedure

Figure 19.8 shows an example of the input capture operation setting procedure.



Figure 19.8 Example of Input Capture Operation Setting Procedure

# (b) Example of Input Capture Operation

Figure 19.9 shows an example of input capture operation.

In this example, both rising and falling edges have been selected as the MTIOCnA pin input capture input edge, the falling edge has been selected as the MTIOCnB pin input capture input edge, and counter clearing by the TGRB input capture has been designated for the TCNT counter.



Figure 19.9 Example of Input Capture Operation

# 19.3.2 Synchronous Operation

In synchronous operation, the values in multiple TCNT counters can be modified simultaneously (synchronous setting). In addition, multiple TCNT counters can be cleared simultaneously (synchronous clearing) by making the appropriate setting in the TCR register.

Synchronous operation increases the number of the TGR registers assigned to a single time base.

MTU0 to MTU2 can all be designated for synchronous operation.

MTU5 cannot be used for synchronous operation.

#### Example of Synchronous Operation Setting Procedure

Figure 19.10 shows an example of the synchronous operation setting procedure.



Figure 19.10 Example of Synchronous Operation Setting Procedure

#### (2) Example of Synchronous Operation

Figure 19.11 shows an example of synchronous operation.

In this example, synchronous operation and PWM mode 1 have been designated for MTU0 to MTU2, compare match of the MTU0.TGRB register has been set as the counter clearing source in MTU0, and synchronous clearing has been set for the counter clearing source in MTU1 and MTU2.

Three-phase PWM waveforms are output from pins MTIOC0A, MTIOC1A, and MTIOC2A. At this time, synchronous setting and synchronous clearing by MTU0.TGRB compare match are performed for the TCNT counters in MTU0 to MTU2, and the data set in the MTU0.TGRB register is used as the PWM cycle.

For details of PWM modes, refer to section 19.3.5, PWM Modes.



Figure 19.11 Example of Synchronous Operation

# 19.3.3 Buffer Operation

Buffer operation, provided for MTU0, enables registers TGRC and TGRD to be used as buffer registers. In MTU0, TGRF register can also be used as a buffer register.

Buffer operation differs depending on whether TGR has been designated as an input capture register or as a compare match register.

Note: MTU0.TGRE register cannot be designated as an input capture register and can only operate as a compare match register.

Table 19.20 shows the register combinations used in buffer operation.

Table 19.20 Register Combinations in Buffer Operation

| Channel | Timer General Register | Buffer Register |  |
|---------|------------------------|-----------------|--|
| MTU0    | TGRA                   | TGRC            |  |
|         | TGRB                   | TGRD            |  |
|         | TGRE                   | TGRF            |  |

## · When TGR register is an output compare register

When a compare match occurs, the value in the buffer register for the corresponding channel is transferred to the timer general register.

This operation is illustrated in Figure 19.12.



Figure 19.12 Compare Match Buffer Operation

#### When TGR register is an input capture register

When an input capture occurs, the value in the TCNT counter is transferred to the TGR register and the value previously held in the TGR register is transferred to the buffer register.

This operation is illustrated in Figure 19.13.



Figure 19.13 Input Capture Buffer Operation

## (1) Example of Buffer Operation Setting Procedure

Figure 19.14 shows an example of the buffer operation setting procedure.



Figure 19.14 Example of Buffer Operation Setting Procedure

#### (2) Examples of Buffer Operation

#### (a) When TGR register is an Output Compare Register

Figure 19.15 shows an operation example in which PWM mode 1 has been designated for MTU0, and buffer operation has been designated for registers TGRA and TGRC. The settings used in this example are TCNT clearing by compare match B, high output at compare match A, and low output at compare match B. In this example, the TBTM.TTSA bit is set to 0.

As buffer operation has been set, when compare match A occurs, the output changes and the value in buffer register TGRC is simultaneously transferred to timer general register TGRA. This operation is repeated each time compare match A occurs.

For details of PWM modes, refer to section 19.3.5, PWM Modes.



Figure 19.15 Example of Buffer Operation (1)

#### (b) When TGR register is an Input Capture Register

Figure 19.16 shows an operation example in which the TGRA register has been designated as an input capture register, and buffer operation has been designated for registers TGRA and TGRC.

Counter clearing by TGRA input capture has been set for the TCNT counter, and both rising and falling edges have been selected as the MTIOCnA pin input capture input edge.

As buffer operation has been set, when the TCNT value is transferred to the TGRA register upon occurrence of input capture A, the value previously stored in the TGRA register is simultaneously transferred to the TGRC register.



Figure 19.16 Example of Buffer Operation (2)

# (3) Selecting Timing for Transfer from Buffer Registers to Timer General Registers in Buffer Operation

The timing for transfer from buffer registers to timer general registers can be selected in PWM mode 1 or 2 for MTU0 by setting the timer buffer operation transfer mode registers (MTU0.TBTM). Either compare match (initial setting) or TCNT clearing can be selected for the transfer timing. TCNT clearing as transfer timing is one of the following cases.

- When the TCNT counter overflows (FFFFh  $\rightarrow$  0000h)
- When 0000h is written to the TCNT counter during counting
- When the TCNT counter is set to 0000h under the condition specified in the TCR.CCLR[2:0] bits

Note: The TBTM register must be modified only while the TCNT counter stops.

Figure 19.17 shows an operation example in which PWM mode 1 is designated for MTU0 and buffer operation is designated for registers MTU0.TGRA and MTU0.TGRC. The settings used in this example are MTU0.TCNT clearing by compare match B, high output at compare match A, and low output at compare match B. The MTU0.TBTM.TTSA bit is set to 1.



Figure 19.17 Example of Buffer Operation When MTU0.TCNT Clearing is Selected for MTU0.TGRC-to-MTU0.TGRA Transfer Timing

## 19.3.4 Cascaded Operation

In cascaded operation, 16-bit counters in different two channels are used together as a 32-bit counter.

This function works when overflow/underflow of the MTU2.TCNT counter is selected as the count clock for MTU1 through the TCR.TPSC[2:0] bits.

Underflow occurs only when the lower 16 bits of the TCNT counter is in phase counting mode.

Table 19.21 lists the register combinations used in cascaded operation.

Note: When phase counting mode is set for MTU1 or MTU2, the count clock setting is invalid and the counters operate independently in phase counting mode.

Table 19.21 Cascaded Combinations

| Combination   | Upper 16 Bits | Lower 16 Bits |
|---------------|---------------|---------------|
| MTU1 and MTU2 | MTU1.TCNT     | MTU2.TCNT     |

For simultaneous input capture of MTU1.TCNT and MTU2.TCNT during cascaded operation, additional input capture input pins can be specified by the TICCR register. The input-capture condition is of edges in the signal produced by taking the logical OR of the input level on the main input pin and the input level on the added input pin. Accordingly, if either is at the high, a change in the level of the other will not produce an edge for detection. For details, refer to (4) Cascaded Operation Example (c). For input capture in cascade connection, refer to section 19.6.16, Simultaneous Input Capture in MTU1.TCNT and MTU2.TCNT in Cascade Connection.

Table 19.22 lists the TICCR setting and input capture input pins.

Table 19.22 TICCR Setting and Input Capture Input Pins

| Target Input Capture            | TICCR Setting                | Input Capture Input Pin |
|---------------------------------|------------------------------|-------------------------|
| Input capture from MTU1.TCNT to | I2AE bit = 0 (initial value) | MTIOC1A                 |
| MTU1.TGRA                       | I2AE bit = 1                 | MTIOC1A, MTIOC2A        |
| Input capture from MTU1.TCNT to | I2BE bit = 0 (initial value) | MTIOC1B                 |
| MTU1.TGRB                       | I2BE bit = 1                 | MTIOC1B, MTIOC2B        |
| Input capture from MTU2.TCNT to | I1AE bit = 0 (initial value) | MTIOC2A                 |
| MTU2.TGRA                       | I1AE bit = 1                 | MTIOC2A, MTIOC1A        |
| Input capture from MTU2.TCNT to | I1BE bit = 0 (initial value) | MTIOC2B                 |
| MTU2.TGRB                       | I1BE bit = 1                 | MTIOC2B, MTIOC1B        |

# (1) Example of Cascaded Operation Setting Procedure

Figure 19.18 shows an example of the cascaded operation setting procedure.



Figure 19.18 Cascaded Operation Setting Procedure

# (2) Cascaded Operation Example (a)

Figure 19.19 shows the operation when the MTU1.TCNT counter is set for counting at MTU2.TCNT overflow/underflow and MTU2 is set for phase counting mode 1 while counters MTU1.TCNT and MTU2.TCNT are cascaded. The MTU1.TCNT counter is incremented by MTU2.TCNT overflow and decremented by MTU2.TCNT underflow.



Figure 19.19 Cascaded Operation Example (a)

#### (3) Cascaded Operation Example (b)

Figure 19.20 illustrates the operation when counters MTU1.TCNT and MTU2.TCNT have been cascaded and the TICCR.I2AE bit has been set to 1 to include the MTIOC2A pin in the MTU1.TGRA input capture conditions. In this example, the MTU1.TIOR.IOA[3:0] bits have selected the MTIOC1A rising edge for the input capture timing while the MTU2.TIOR.IOA[3:0] bits have selected the MTIOC2A rising edge for the input capture timing. Under these conditions, the rising edge of both MTIOC1A and MTIOC2A is used for the MTU1.TGRA input capture condition. For the MTU2.TGRA input capture condition, the MTIOC2A rising edge is used.



Figure 19.20 Cascaded Operation Example (b)

#### (4) Cascaded Operation Example (c)

Figure 19.21 illustrates the operation when counters MTU1.TCNT and MTU2.TCNT have been cascaded and the I2AE and I1AE bits in TICCR register have been set to 1 to include the MTIOC2A and MTIOC1A pins in the MTU1.TGRA and MTU2.TGRA input capture conditions, respectively. In this example, the IOA[3:0] bits in both MTU1.TIOR and MTU2.TIOR registers have selected both the rising and falling edges for the input capture timing. Under these conditions, the OR result of MTIOC1A and MTIOC2A input is used for the MTU1.TGRA and MTU2.TGRA input capture conditions.



Figure 19.21 Cascaded Operation Example (c)

## (5) Cascaded Operation Example (d)

Figure 19.22 illustrates the operation when counters MTU1.TCNT and MTU2.TCNT have been cascaded and the TICCR.I2AE bit has been set to 1 to include the MTIOC2A pin in the MTU1.TGRA input capture conditions. In this example, the MTU1.TIOR.IOA[3:0] bits have selected occurrence of MTU0.TGRA compare match or input capture for the input capture timing while the MTU2.TIOR.IOA[3:0] bits have selected the MTIOC2A rising edge for the input capture timing.

Under these conditions, as the MTU1.TIOR register has selected occurrence of MTU0.TGRA compare match or input capture for the input capture timing, the MTIOC2A edge is not used for MTU1.TGRA input capture condition although the TICCR.I2AE bit has been set to 1.



Figure 19.22 Cascaded Operation Example (d)

#### 19.3.5 PWM Modes

PWM modes are provided to output PWM waveforms from the external pins. The output level can be selected as low, high, or toggle output in response to a compare match of each TGR register.

PWM waveforms in the range of 0% to 100% duty cycle can be output according to the TGR settings.

By designating TGR compare match as the counter clearing source, the PWM cycle can be specified in that register. Every channel can be set to PWM mode independently. Channels set to PWM mode can perform synchronous operation with each other or other channels set to any other mode.

There are two PWM modes as described below.

#### (a) PWM Mode 1

PWM waveforms are output from the MTIOCnA and MTIOCnC pins by pairing the TGRA register with the TGRB register and the TGRC register with the TGRD register. The levels specified by the TIOR.IOA[3:0] and IOC[3:0] bits are output from the MTIOCnA and MTIOCnC pins at compare matches A and C, and the levels specified by the TIOR.IOB[3:0] and IOD[3:0] bits are output at compare matches B and D. The initial output value is set in the TGRA register or the TGRC register. If the values set in paired TGRs are identical, the output value does not change even when a compare match occurs.

In PWM mode 1, up to eight phases of PWM waveforms can be output.

#### (b) PWM Mode 2

PWM output is generated using one TGR register as the cycle register and the others as duty registers. The level specified in the TIOR register is output at compare matches. Upon counter clearing by a cycle register compare match, the initial value set in the TIOR register is output from each pin. If the values set in the cycle and duty registers are identical, the output value does not change even when a compare match occurs.

In PWM mode 2, up to eight phases of PWM waveforms can be output when using synchronous operation in combination.

The correspondence between PWM output pins and registers is listed in Table 19.23.

Table 19.23 PWM Output Registers and Output Pins

|         |           | Output Pins |            |
|---------|-----------|-------------|------------|
| Channel | Register  | PWM Mode 1  | PWM Mode 2 |
| MTU0    | MTU0.TGRA | MTIOC0A     | MTIOC0A    |
|         | MTU0.TGRB |             | MTIOC0B    |
|         | MTU0.TGRC | MTIOC0C     | MTIOC0C    |
|         | MTU0.TGRD |             | MTIOC0D    |
| MTU1    | MTU1.TGRA | MTIOC1A     | MTIOC1A    |
|         | MTU1.TGRB |             | MTIOC1B    |
| MTU2    | MTU2.TGRA | MTIOC2A     | MTIOC2A    |
|         | MTU2.TGRB |             | MTIOC2B    |

Note: In PWM mode 2, PWM output is not possible for the TGR register in which the PWM cycle is set.



# (1) Example of PWM Mode Setting Procedure

Figure 19.23 shows an example of the PWM mode setting procedure.



Figure 19.23 Example of PWM Mode Setting Procedure

# (2) Examples of PWM Mode Operation

Figure 19.24 shows an example of operation in PWM mode 1.

In this example, TGRA compare match is set as the TCNT clearing source, a low level is set as the initial output value and output value for the TGRA register, and a high level is set as the output value for the TGRB register.

In this case, the value set in the TGRA register is used as the cycle, and the value set in the TGRB register is used as the duty.



Figure 19.24 Example of PWM Mode Operation

Figure 19.25 shows an example of operation in PWM mode 2.

In this example, synchronous operation is designated for MTU0 and MTU1, MTU1.TGRB compare match is set as the TCNT clearing source, and a low level is set as the initial output value and a high level as the output value for the other TGR registers (MTU0.TGRA to MTU0.TGRD and MTU1.TGRA), outputting 5-phase PWM waveforms.

In this case, the value set in the MTU1.TGRB register is used as the cycle, and the values set in the other TGR registers are used as the duty.



Figure 19.25 Example of PWM Mode Operation

Figure 19.26 shows examples of PWM waveform output with 0% duty and 100% duty in PWM mode 1. In this example, TGRA compare match is set as the TCNT clearing source, a low level is set as the initial output value and output value for the TGRA register, and a high level is set as the output value for the TGRB register.



Figure 19.26 Examples of PWM Mode Operation

# 19.3.6 Phase Counting Mode

When phase counting mode is specified, an external clock is selected as the count clock and the TCNT counter operates as an up-counter/down-counter regardless of the setting of the TCR.TPSC[2:0] bits and TCR.CKEG[1:0] bits. However, the functions of the TCR.CCLR[2:0] bits and of registers TIOR, TIER, and TGR are valid, and input capture/compare match and interrupt functions can be used.

This can be used for 2-phase encoder pulse input.

If an overflow occurs while the TCNT counter is counting up, a TCIV interrupt is generated while the corresponding TIER.TCIEV bit is 1. If an underflow occurs while the TCNT counter is counting down, a TCIU interrupt is generated while the corresponding TIER.TCIEU bit is 1.

The TSR.TCFD flag is the count direction flag. Read the TCFD flag to check whether the TCNT counter is counting up or down.

In phase counting mode, the external clock pins MTCLKA, MTCLKB, MTCLKC, and MTCLKD can be used as 2-phase encoder pulse input pins. Table 19.24 lists the correspondence between external clock pins and channels.

Table 19.24 Clock Input Pins in Phase Counting Mode

| External Clock Input Pins |         | Pins    |
|---------------------------|---------|---------|
| Channel                   | A-Phase | B-Phase |
| MTU1                      | MTCLKA  | MTCLKB  |
| MTU2                      | MTCLKC  | MTCLKD  |

## (1) Example of Phase Counting Mode Setting Procedure

Figure 19.27 shows an example of the phase counting mode setting procedure.



Figure 19.27 Example of Phase Counting Mode Setting Procedure

## (2) Examples of Phase Counting Mode Operation

In phase counting mode, the TCNT counter is incremented or decremented according to the phase difference between two external clocks. There are four modes according to the count conditions.

# (a) Phase Counting Mode 1

Figure 19.28 shows an example of operation in phase counting mode 1, and Table 19.25 lists the TCNT up-counting and down-counting conditions.



Figure 19.28 Example of Operation in Phase Counting Mode 1

Table 19.25 Up-Counting and Down-Counting Conditions in Phase Counting Mode 1

| MTCLKA (MTU1)<br>MTCLKC (MTU2) | MTCLKB (MTU1)<br>MTCLKD (MTU2) | Operation     |
|--------------------------------|--------------------------------|---------------|
| High                           |                                | Up-counting   |
| Low                            | ₹_                             |               |
|                                | Low                            |               |
| ₹                              | High                           |               |
| High                           | ₹_                             | Down-counting |
| Low                            |                                |               |
|                                | High                           |               |
| ₹_                             | Low                            |               |

: Rising edge

# (b) Phase Counting Mode 2

Figure 19.29 shows an example of operation in phase counting mode 2, and Table 19.26 lists the TCNT up-counting and down-counting conditions.



Figure 19.29 Example of Operation in Phase Counting Mode 2

Table 19.26 Up-Counting and Down-Counting Conditions in Phase Counting Mode 2

| MTCLKA (MTU1)<br>MTCLKC (MTU2) | MTCLKB (MTU1)<br>MTCLKD (MTU2) | Operation         |
|--------------------------------|--------------------------------|-------------------|
| High                           |                                | None (Don't care) |
| Low                            | ₹_                             | None (Don't care) |
|                                | Low                            | None (Don't care) |
| ₹                              | High                           | Up-counting       |
| High                           | ₹_                             | None (Don't care) |
| Low                            |                                | None (Don't care) |
|                                | High                           | None (Don't care) |
| <u> </u>                       | Low                            | Down-counting     |

: Rising edge

# (c) Phase Counting Mode 3

Figure 19.30 shows an example of operation in phase counting mode 3, and Table 19.27 lists the TCNT up-counting and down-counting conditions.



Figure 19.30 Example of Operation in Phase Counting Mode 3

Table 19.27 Up-Counting and Down-Counting Conditions in Phase Counting Mode 3

| MTCLKA (MTU1)<br>MTCLKC (MTU2) | MTCLKB (MTU1)<br>MTCLKD (MTU2) | Operation                   |
|--------------------------------|--------------------------------|-----------------------------|
| High                           |                                | None (Don't care)           |
| Low                            |                                | None (Don't care)           |
|                                | Low                            | None (Don't care)           |
| ▼_                             | High                           | Up-counting Up-counting     |
| High                           |                                | Down-counting Down-counting |
| Low                            |                                | None (Don't care)           |
|                                | High                           | None (Don't care)           |
|                                | Low                            | None (Don't care)           |

∴ Rising edge : Falling edge

# (d) Phase Counting Mode 4

Figure 19.31 shows an example of operation in phase counting mode 4, and Table 19.28 lists the TCNT up-counting and down-counting conditions.



Figure 19.31 Example of Operation in Phase Counting Mode 4

Table 19.28 Up-Counting and Down-Counting Conditions in Phase Counting Mode 4

| MTCLKA (MTU1)<br>MTCLKC (MTU2) | MTCLKB (MTU1)<br>MTCLKD (MTU2) | Operation         |
|--------------------------------|--------------------------------|-------------------|
| High                           |                                | Up-counting       |
| Low                            | ₹_                             | <del></del>       |
|                                | Low                            | None (Don't care) |
|                                | High                           |                   |
| High                           | ₹_                             | Down-counting     |
| Low                            |                                |                   |
|                                | High                           | None (Don't care) |
|                                | Low                            |                   |

: Rising edge

#### (3) Phase Counting Mode Application Example

Figure 19.32 shows an example in which MTU1 is in phase counting mode, and MTU1 is coupled with MTU0 to input 2-phase encoder pulses of a servo motor in order to detect position or speed.

MTU1 is set to phase counting mode 1, and the encoder pulse A-phase and B-phase are input to MTCLKA and MTCLKB

MTU0.TGRC compare match is specified as the MTU0.TCNT clearing source and registers MTU0.TGRA and MTU0.TGRC are used for the compare match function and are set with the speed control cycle and position control cycle. The MTU0.TGRB register is used for input capture, with registers MTU0.TGRB and MTU0.TGRD operating in buffer mode. The MTU1 count clock is designated as the MTU0.TGRB input capture source, and the widths of 2-phase encoder 4-multiplication pulses are detected.

Registers MTU1.TGRA and MTU1.TGRB are designated for the input capture function and the MTU0.TGRA and MTU0.TGRC compare matches are selected as the input capture sources to store the up-counter/down-counter values for the control cycles.

This procedure enables the accurate detection of position and speed.



Figure 19.32 Phase Counting Mode Application Example

#### 19.3.7 External Pulse Width Measurement

Up to three external pulse widths can be measured in MTU5.

When the IOC[4:0] bits in MTU5.TIORU, TIORV, and TIORW are set for pulse width measurement, the pulse width of the signal input to the MTIC5U, MTIC5V, and MTIC5W pins is measured. Counters TCNTU, TCNTV, and TCNTW count up while the level specified by the IOC[4:0] bits is input.

Figure 19.33 shows an example of setting external pulse width measurement, and Figure 19.34 an example of external pulse width measurement.



Figure 19.33 Example of External Pulse Width Measurement Setting Procedure



Figure 19.34 Example of External Pulse Width Measurement (Measuring High Pulse Width)

#### 19.3.8 Noise Filter

Each pin for use in input capture and external pulse input to the MTU is equipped with a noise filter. The noise filter samples input signals at the sampling clock and removes the pulses of which length is less than three sampling cycles. The noise filter functionality includes enabling and disabling of the noise filter for each pin and setting of the sampling clock for each channel. Figure 19.35 shows the timing of noise filtering.



Figure 19.35 Timing of Noise Filtering

## 19.4 Interrupt Sources

## 19.4.1 Interrupt Sources and Priorities

There are three interrupt sources; the TGR input capture/compare match, the TCNT counter overflow, and the TCNT counter underflow. Each interrupt source has its own enable/disable bit, allowing the generation of interrupt request signals to be enabled or disabled individually.

When an interrupt source is detected, an interrupt is requested if the corresponding enable/disable bit in the TIER register is set to 1.

Relative channel priorities can be changed by the interrupt controller; however the priority within a channel is fixed. For details, refer to section 14, Interrupt Controller (ICUb).

Table 19.29 lists the MTU interrupt sources.

Table 19.29 MTU Interrupt Sources (1)

| Channel | Name  | Interrupt Source                      | DTC<br>Activation | Priority |
|---------|-------|---------------------------------------|-------------------|----------|
| MTU0    | TGIA0 | MTU0.TGRA input capture/compare match | Possible          | High     |
|         | TGIB0 | MTU0.TGRB input capture/compare match | Possible          | _ ♦      |
|         | TGIC0 | MTU0.TGRC input capture/compare match | Possible          | _        |
|         | TGID0 | MTU0.TGRD input capture/compare match | Possible          | _        |
|         | TCIV0 | MTU0.TCNT overflow                    | Not possible      | _        |
|         | TGIE0 | MTU0.TGRE compare match               | Not possible      | _        |
|         | TGIF0 | MTU0.TGRF compare match               | Not possible      | _        |
| MTU1    | TGIA1 | MTU1.TGRA input capture/compare match | Possible          | _        |
|         | TGIB1 | MTU1.TGRB input capture/compare match | Possible          | _        |
|         | TCIV1 | MTU1.TCNT overflow                    | Not possible      | _        |
|         | TCIU1 | MTU1.TCNT underflow                   | Not possible      | _        |
| MTU2    | TGIA2 | MTU2.TGRA input capture/compare match | Possible          | _        |
|         | TGIB2 | MTU2.TGRB input capture/compare match | Possible          | _        |
|         | TCIV2 | MTU2.TCNT overflow                    | Not possible      | _        |
|         | TCIU2 | MTU2.TCNT underflow                   | Not possible      | _        |
| MTU5    | TGIU5 | MTU5.TGRU input capture/compare match | Possible          | _        |
|         | TGIV5 | MTU5.TGRV input capture/compare match | Possible          | _        |
|         | TGIW5 | MTU5.TGRW input capture/compare match | Possible          | Low      |

Note: This table lists the initial state immediately after a reset. The relative channel priorities can be changed by the interrupt controller.

#### (1) Input Capture/Compare Match Interrupt

An interrupt is requested if the TIER.TGIE bit is set to 1 when a TGR input capture/compare match occurs on a channel. The MTU has 13 input capture/compare match interrupts (six for MTU0, two each for MTU1 and MTU2, and three for MTU5).

#### (2) Overflow Interrupt

An interrupt is requested if the TIER.TGIE bit is set to 1 when a TCNT counter overflow occurs on a channel. The MTU has three overflow interrupts (one for each channel).

#### (3) Underflow Interrupt

An interrupt is requested if the TIER.TCIEU bit is set to 1 when a TCNT counter underflow occurs on a channel. The MTU has two underflow interrupts (one each for MTU1 and MTU2).



#### 19.4.2 DTC Activation

The DTC can be activated by the TGR input capture/compare match interrupt in each channel. For details, refer to section 16, Data Transfer Controller (DTCa).

The MTU provides a total of 11 input capture/compare match interrupts and overflow interrupts that can be used as DTC activation sources: four for MTU0, two each for MTU1 and MTU2, and three for MTU5.

#### 19.4.3 A/D Converter Activation

The A/D converter can be activated by one of the following five methods in the MTU. Table 19.30 lists the relationship between interrupt sources and A/D converter start request signals.

#### (1) A/D Converter Activation by TGRA Input Capture/Compare Match

The A/D converter can be activated by the occurrence of a TGRA input capture/compare match in each channel. A/D converter start request signal TRGAN is issued to the A/D converter under the following condition.

• When a TGRA input capture/compare match occurs on a channel while the TIER.TTGE bit is set to 1 When the condition is satisfied, if A/D converter start signal TRGAN from the MTU is selected as the trigger in the A/D converter, A/D conversion will start.

#### (2) A/D Converter Activation by Compare Match between MTU0.TCNT and MTU0.TGRE

A compare match between the MTU0.TCNT counter and the MTU0.TGRE register activates the A/D converter. A/D converter start request signal TRG0EN is issued when a compare match occurs between the MTU0.TCNT counter and the MTU0.TGRE register. If A/D converter start signal TRG0EN from the MTU is selected as the trigger in the A/D converter, A/D conversion will start.

#### (3) A/D Converter Activation by Compare Match between MTU0.TCNT and MTU0.TGRF

An input capture or compare match between the MTU0.TCNT counter and the MTU0.TGRA or MTU0.TGRB register activates the A/D converter.

A compare match between the MTU0.TCNT counter and the MTU0.TGRF register activates the A/D converter. A/D converter start request signal TRG0FN is issued when a compare match occurs between the MTU0.TCNT counter and the MTU0.TGRF register. If A/D converter start signal TRG0FN from the MTU is selected as the trigger in the A/D converter. A/D conversion will start.

# (4) A/D Converter Activation by Input Capture or Compare Match with MTU0.TGRA or TGRB

The A/D converter can be activated when an input capture or compare match occurs between the MTU0.TCNT counter and the MTU0.TGRA or MTU0.TGRB register.

When an input capture or compare match occurs between the MTU0.TCNT counter and the MTU0.TGRA or MTU0.TGRB register. A/D converter start request signal TRG0AN or TRG0BN is issued. If A/D converter start signal TRG0AN or TRG0BN from the MTU is selected as the trigger in the A/D converter, A/D conversion will start.

Table 19.30 Interrupt Sources and A/D Converter Start Request Signals

| Target Registers        | A/D Start Request Source    | A/D Converter Start Request Signal |  |
|-------------------------|-----------------------------|------------------------------------|--|
| MTU0.TGRA and MTU0.TCNT | Input capture/compare match | TRGAN                              |  |
| MTU1.TGRA and MTU1.TCNT |                             |                                    |  |
| MTU2.TGRA and MTU2.TCNT |                             |                                    |  |
| MTU0.TGRA and MTU0.TCNT | Input capture/compare match | TRG0AN                             |  |
| MTU0.TGRB and MTU0.TCNT |                             | TRG0BN                             |  |
| MTU0.TGRE and MTU0.TCNT | Compare match               | TRG0EN                             |  |
| MTU0.TGRF and MTU0.TCNT |                             | TRG0FN                             |  |



# 19.5 Operation Timing

# 19.5.1 Input/Output Timing

# (1) TCNT Count Timing

Figure 19.36 and Figure 19.37 show the TCNT count timing for TGI interrupt in internal clock operation, Figure 19.38 shows the TCNT count timing in external clock operation (normal mode), and Figure 19.39 shows the TCNT count timing in external clock operation (phase counting mode).



Figure 19.36 Count Timing in Internal Clock Operation (MTU0 to MTU2)



Figure 19.37 Count Timing in Internal Clock Operation (MTU5)



Figure 19.38 Count Timing in External Clock Operation (MTU0 to MTU2)



Figure 19.39 Count Timing in External Clock Operation (Phase Counting Mode)

#### (2) Output Compare Output Timing

A compare match signal is generated in the final state in which the TCNT counter and the TGR register match (the point at which the count value matched is updated by the TCNT counter). When a compare match signal is generated, the value set in the TIOR register is output to the output compare output pin (MTIOC pin). After a match between the TCNT counter and the TGR register, the compare match signal is not generated until the TCNT count clock is generated. Figure 19.40 shows the output compare output timing (normal mode or PWM mode).



Figure 19.40 Output Compare Output Timing (Normal Mode or PWM Mode)

# (3) Input Capture Signal Timing

Figure 19.41 shows the input capture signal timing.



Figure 19.41 Input Capture Input Signal Timing

## (4) Timing for Counter Clearing by Compare Match/Input Capture

Figure 19.42 and Figure 19.43 show the timing when counter clearing on compare match is specified, and Figure 19.44 shows the timing when counter clearing on input capture is specified.



Figure 19.42 Counter Clear Timing (Compare Match) (MTU0 to MTU2)



Figure 19.43 Counter Clear Timing (Compare Match) (MTU5)



Figure 19.44 Counter Clear Timing (Input Capture) (MTU0 to MTU2, MTU5)

# (5) Buffer Operation Timing

Figure 19.45 to Figure 19.47 show the timing in buffer operation.



Figure 19.45 Buffer Operation Timing (Compare Match)



Figure 19.46 Buffer Operation Timing (Input Capture)



Figure 19.47 Buffer Operation Timing (When TCNT Cleared)

# 19.5.2 Interrupt Signal Timing

# (1) Timing for TGI Interrupt by Compare Match

Figure 19.48 and Figure 19.49 show the TGI interrupt request signal timing on compare match.



Figure 19.48 TGI Interrupt Timing (Compare Match) (MTU0 to MTU2)



Figure 19.49 TGI Interrupt Timing (Compare Match) (MTU5)

### (2) Timing for TGI Interrupt by Input Capture

Figure 19.50 and Figure 19.51 show TGI interrupt request signal timing on input capture.



Figure 19.50 TGI Interrupt Timing (Input Capture) (MTU0 to MTU2)



Figure 19.51 TGI Interrupt Timing (Input Capture) (MTU5)

### (3) TCIV and TCIU Interrupt Timing

Figure 19.52 shows the TCIV interrupt request signal timing on overflow.

Figure 19.53 shows the TCIU interrupt request signal timing on underflow.



Figure 19.52 TCIV Interrupt Timing



Figure 19.53 TCIU Interrupt Timing

#### 19.6 Usage Notes

### 19.6.1 Module Clock Stop Mode Setting

MTU operation can be disabled or enabled using the module stop control register. MTU operation is stopped with the initial setting. Register access is enabled by releasing the module clock stop mode. For details, refer to section 11, Low Power Consumption.

#### 19.6.2 Count Clock Restrictions

The count clock source pulse width must be at least 1.5 PCLK cycles for single-edge detection, and at least 2.5 PCLK cycles for both-edge detection. The MTU will not operate properly at narrower pulse widths.

In phase counting mode, the phase difference and overlap between the two input clocks must be at least 1.5 PCLK cycles, and the pulse width must be at least 2.5 PCLK cycles. Figure 19.54 shows the input clock conditions in phase counting mode.



Figure 19.54 Phase Difference, Overlap, and Pulse Width in Phase Counting Mode

### 19.6.3 Notes on Cycle Setting

When counter clearing on compare match is set, the TCNT counter is cleared in the final state in which it matches the TGR register value (the point at which the TCNT counter updates the matched count value). Consequently, the actual counter frequency is given by the following formula:

• MTU0 to MTU2

$$f = \frac{CNTCLK}{N+1}$$

• MTU5

$$f \, = \, \frac{CNTCLK}{N}$$

f: Counter frequency

CNTCLK: The count clock frequency set by the TCR.TPSC[2:0] bits

N: The TGR register setting

### 19.6.4 Contention between TCNT Write and Clear Operations

If the counter clear signal is generated in a TCNT write cycle, the TCNT counter clearing takes precedence and the TCNT counter write operation is not performed.

Figure 19.55 shows the timing in this case.



Figure 19.55 Contention between TCNT Write and Counter Clear Operations

### 19.6.5 Contention between TCNT Write and Increment Operations

If incrementing occurs in a TCNT write cycle, the TCNT counter write operation takes precedence and the TCNT counter is not incremented.

Figure 19.56 shows the timing in this case.



Figure 19.56 Contention between TCNT Write and Increment Operations

### 19.6.6 Contention between TGR Write Operation and Compare Match

If a compare match occurs in a TGR write cycle, the TGR register write operation is executed and the compare match signal is also generated.

Figure 19.57 shows the timing in this case.



Figure 19.57 Contention between TGR Write Operation and Compare Match

### 19.6.7 Contention between Buffer Register Write Operation and Compare Match

If a compare match occurs in a TGR write cycle, the data before write operation is transferred to the TGR register by the buffer operation.

Figure 19.58 shows the timing in this case.



Figure 19.58 Contention between Buffer Register Write Operation and Compare Match

### 19.6.8 Contention between Buffer Register Write and TCNT Clear Operations

When the buffer transfer timing is set at the TCNT clear timing by the timer buffer operation transfer mode register (TBTM), if TCNT clearing occurs in a TGR write cycle, the data before write operation is transferred to TGR by the buffer operation.

Figure 19.59 shows the timing in this case.



Figure 19.59 Contention between Buffer Register Write and TCNT Clear Operations

### 19.6.9 Contention between TGR Read Operation and Input Capture

If an input capture signal is generated in a TGR read cycle, the data before input capture transfer is read. Figure 19.60 shows the timing in this case.



Figure 19.60 Contention between TGR Read Operation and Input Capture (MTU0 to MTU2, MTU5)

### 19.6.10 Contention between TGR Write Operation and Input Capture

If an input capture signal is generated in a TGR write cycle, the input capture operation takes precedence and the TGR register write operation is not performed in MTU0 to MTU2. In MTU5, the TGR register write operation is performed and the input capture signal is generated.

Figure 19.61 and Figure 19.62 show the timing in this case.



Figure 19.61 Contention between TGR Write Operation and Input Capture (MTU0 to MTU2)



Figure 19.62 Contention between TGR Write Operation and Input Capture (MTU5)

### 19.6.11 Contention between Buffer Register Write Operation and Input Capture

If an input capture signal is generated in a buffer register write cycle, the buffer operation takes precedence and the buffer register write operation is not performed.

Figure 19.63 shows the timing in this case.



Figure 19.63 Contention between Buffer Register Write Operation and Input Capture

### 19.6.12 Contention between MTU2.TCNT Write Operation and Overflow/Underflow in Cascaded Operation

With timer counters MTU1.TCNT and MTU2.TCNT in a cascade, when a contention occurs between MTU1.TCNT counting (an MTU2.TCNT counter overflow/underflow) and the MTU2.TCNT write cycle, the MTU2.TCNT write operation is performed and the MTU1.TCNT count signal is disabled. In this case, if the MTU1.TGRA register works as a compare match register and there is a match between the MTU1.TGRA register and the MTU1.TCNT counter values, a compare match signal is issued.

Furthermore, when the MTU1.TCNT count clock is selected as the input capture source of MTU0, registers MTU0.TGRA to MTU0.TGRD work in input capture mode. In addition, when the MTU0.TGRC compare match/input capture is selected as the input capture source of the MTU1.TGRB register, the MTU1.TGRB register works in input capture mode.

Figure 19.64 shows the timing in this case.

When setting the TCNT clearing function in cascaded operation, be sure to synchronize MTU1 and MTU2.



Figure 19.64 Contention between MTU2.TCNT Write Operation and Overflow/Underflow in Cascaded Operation

### 19.6.13 Contention between Overflow/Underflow and Counter Clearing

If an overflow/underflow and counter clearing occur simultaneously, the TCNT counter clearing takes precedence and the corresponding TCIV interrupt is not generated. If an overflow and counter clearing due to an input capture occur simultaneously, an input capture interrupt signal is output and an overflow interrupt signal is not output.

Figure 19.65 shows the operation timing when a TGR compare match is specified as the clearing source and the TGR register is set to FFFFh.



Figure 19.65 Contention between Overflow and Counter Clearing

### 19.6.14 Contention between TCNT Write Operation and Overflow/Underflow

If TCNT up-count or down-count in a TCNT write cycle and an overflow or an underflow occurs, the TCNT write operation takes precedence. The corresponding interrupt is not generated.

Figure 19.66 shows the operation timing when there is contention between TCNT write operation and overflow.



Figure 19.66 Contention between TCNT Write Operation and Overflow

### 19.6.15 Interrupts during Periods in the Module Stop State

When an module that has issued an interrupt request enters the module stop state, clearing the source of the interrupt for the CPU or activation signal for the DTC is not possible.

Accordingly, disable interrupts, etc. before making the settings for the module stop state.

### 19.6.16 Simultaneous Input Capture in MTU1.TCNT and MTU2.TCNT in Cascade Connection

When counters MTU1.TCNT and MTU2.TCNT operate as a 32-bit counter in cascade connection, the cascaded counter value cannot be captured successfully in some cases even if input-capture input is simultaneously done to MTIOC1A and MTIOC2A or to MTIOC1B and MTIOC2B. This is because the input timing of MTIOC1A and MTIOC2A or of MTIOC1B and MTIOC2B may not be the same when external input-capture signals input into counters MTU1.TCNT and MTU2.TCNT are taken in synchronization with the internal clock.

For example, the MTU1.TCNT counter (the counter for upper 16 bits) does not capture the count-up value by an overflow from the MTU2.TCNT counter (the counter for lower 16 bits) but captures the count value before the upcounting. In this case, the values of MTU1.TCNT = FFF1h and MTU2.TCNT = 0000h should be transferred to registers MTU1.TGRA and MTU2.TGRA or to registers MTU1.TGRB and MTU2.TGRB, but the values of MTU1.TCNT = FFF0h and MTU2.TCNT = 0000h are erroneously transferred.

The MTU has a function that allows simultaneous capture of counters MTU1.TCNT and MTU2.TCNT with a single input capture input. This function can be used to read the 32-bit counter such that counters MTU1.TCNT and MTU2.TCNT are captured at the same time. For details, refer to section 19.2.8, Timer Input Capture Control Register (TICCR).

#### 19.6.17 Point for Caution Regarding MTU5.TCNT and MTU5.TGR Registers

Do not set an MTU5.TGRm (m = U, V, W) register to the value of the corresponding MTU5.TCNTm counter value plus one while counting by the MTU5.TCNTm counter is stopped. If an MTU5.TGRm register is set to the value of the corresponding MTU5.TCNTm counter value plus one while counting by the MTU5.TCNTm counter is stopped, a compare-match will be generated even though counting is stopped.

In this case, if the corresponding MTU5.TIER.TGIE5m bit is also set to 1 (interrupt requests enabled), a compare-match interrupt will also be generated. If the value of the timer compare match clear register is also 1 (enabled), the MTU5.TCNTm counter is automatically cleared to 0000h when the compare-match is generated, regardless of whether compare-match interrupt is enabled or disabled.



### 19.6.18 Continuous Output of Interrupt Signal in Response to a Compare Match

When the TGR register is set to 0000h, PCLK/1 is set as the count clock, and compare match is set as the trigger for clearing of the count clock, the value of the TCNT counter remains 0000h, and the interrupt signal will be output continuously (i.e. its level will be flat) rather than output over a single cycle. Consequently, interrupts will not be detected in response to second and subsequent compare matches.

Figure 19.67 shows the timing for continuous output of the interrupt signal in response to a compare match.



Figure 19.67 Continuous Output of Interrupt Signal in Response to a Compare Match

#### 19.7 MTU Output Pin Initialization

### 19.7.1 Operating Modes

The MTU has the following four operating modes. Waveforms can be output in any of these modes.

- Normal mode (MTU0 to MTU2)
- PWM mode 1 (MTU0 to MTU2)
- PWM mode 2 (MTU0 to MTU2)
- Phase counting modes 1 to 4 (MTU1 and MTU2)

This section describes how to initialize the MTU output pins in each of these modes.

### 19.7.2 Operation in Case of Re-Setting Due to Error during Operation

If an error occurs during MTU operation, MTU output should be cut off by the system. For an I/O port that is shut down, set the port direction registers (PDR), the port output data register (PODR), and the port mode register (PMR) to switch the port pins to be general output pins and for output of the non-active level. The pin initialization procedures for resetting due to an error during operation and the procedures for restarting in a different mode after re-setting are described below.

The MTU has four operating modes, as stated above. There are thus 16 mode transition combinations, but some transitions are not available with certain channel and mode combinations. Available mode transition combinations are listed in Table 19.31.

Note that the following notations are used for operating modes.

Normal: Normal mode PWM1: PWM mode 1 PWM2: PWM mode 2

PCM: Phase counting modes 1 to 4

**Table 19.31** Mode Transition Combinations

|        | Normal | PWM1 | PWM2 | PCM  |
|--------|--------|------|------|------|
| Normal | (1)    | (2)  | (3)  | (4)  |
| PWM1   | (5)    | (6)  | (7)  | (8)  |
| PWM2   | (9)    | (10) | (11) | (12) |
| PCM    | (13)   | (14) | (15) | (16) |

### 19.7.3 Overview of Pin Initialization Procedures and Mode Transitions in Case of Error during Operation

- When making a transition to a mode (Normal, PWM1, PWM2, or PCM) in which the pin output level is selected by the TIOR register setting, initialize the pins by means of the TIOR register setting.
- In PWM mode 2, waveforms are not output to the cycle register pins. When a pin is configured for MTIOCnm (n = 0 to 2; m = A to D), it enters high-impedance state. To output a specified level, set the pin to general output port.
- In normal mode or PWM 2 mode, if the TGRC and TGRD register operate as buffer registers, waveforms are not output to the corresponding pins (MTIOC0C or MTIOC0D). When a pin is configured for MTIOC0C or MTIOC0D, it enters high-impedance state. To output a specified level, set the pin to general output port.
- In PWM mode 1, if either TGRC or TGRD register operates as a buffer register, waveforms are not output to the corresponding pins (MTIOC0C or MTIOC0D). When a pin is configured for MTIOC0C or MTIOC0D, it enter high-impedance state. To output a specified level, set the pin to general output port.

Note: Channel number is substituted for "n" indicated in this section unless otherwise specified.

Pin initialization procedures are described below for the numbered combinations in Table 19.31. The active level is assumed to be low.

### (1) Operation When Error Occurs in Normal Mode and Operation is Restarted in Normal Mode

Figure 19.68 shows a case in which an error occurs in normal mode and operation is restarted in normal mode after resetting.



Figure 19.68 Error Occurrence in Normal Mode, Recovery in Normal Mode

- [1] After a reset, the MTU output goes low and the ports enter high-impedance state.
- [2] After a reset, the TMDR setting is for normal mode.
- [3] Initialize the pins with the TIOR register. (In the example, the initial output is a high level, and a low level is output on compare match occurrence.)
- [4] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [5] Start count operation by setting the TSTR register.
- [6] Output goes low on compare match occurrence.
- [7] An error occurs.
- [8] Use the port direction register (PDR) and port mode register (PMR) for the input port pin to switch it to operate as a general output port pin, and the port output data register (PODR) to select output of the non-active level.
- [9] Stop count operation by setting the TSTR register.
- [10] This step is not necessary when restarting in normal mode.
- [11] Initialize the pins with the TIOR register.
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

(2) Operation When Error Occurs in Normal Mode and Operation is Restarted in PWM Mode 1 Figure 19.69 shows a case in which an error occurs in normal mode and operation is restarted in PWM mode 1 after resetting.



Figure 19.69 Error Occurrence in Normal Mode, Recovery in PWM Mode 1

- [1] to [9] are the same as in Figure 19.68.
- [10]Set PWM mode 1.
- [11]Set the TIOR register to initialize pins, i.e. so that the MTIOCnB (or MTIOCnD) does not produce a waveform in PWM mode 1. If a particular level should be output, set the port direction register (PDR) and the port output data register (PODR) so that the pins of the I/O port operate as general outputs.
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

# (3) Operation When Error Occurs in Normal Mode and Operation is Restarted in PWM Mode 2 Figure 19.70 shows a case in which an error occurs in normal mode and operation is restarted in PWM mode 2 after resetting.



Figure 19.70 Error Occurrence in Normal Mode, Recovery in PWM Mode 2

- [1] to [9] are the same as in Figure 19.68.
- [10] Set PWM mode 2.
- [11] Initialize the pins with the TIOR register. (In PWM mode 2, the cycle register pins are not initialized. If initialization is required, initialize in normal mode, then switch to PWM mode 2.)
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.



### (4) Operation When Error Occurs in Normal Mode and Operation is Restarted in Phase Counting Mode

Figure 19.71 shows a case in which an error occurs in normal mode and operation is restarted in phase counting mode after re-setting.



Figure 19.71 Error Occurrence in Normal Mode, Recovery in Phase Counting Mode

- [1] to [9] are the same as in Figure 19.68.
- [10] Set the phase counting mode.
- [11] Initialize the pins with the TIOR register.
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

## (5) Operation When Error Occurs in PWM Mode 1 and Operation is Restarted in Normal Mode Figure 19.72 shows a case in which an error occurs in PWM mode 1 and operation is restarted in normal mode after resetting.



Figure 19.72 Error Occurrence in PWM Mode 1, Recovery in Normal Mode

- [1] After a reset, the MTU output goes low and the ports enter high-impedance state.
- [2] Set PWM mode 1.
- [3] Initialize the pins with the TIOR register. (In the example, the initial output is a high level, and a low level is output on compare match occurrence. In PWM mode 1, the MTIOCnB side is not initialized.)
- [4] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [5] Start count operation by setting the TSTR register.
- [6] Output goes low on compare match occurrence.
- [7] An error occurs.
- [8] Use the port direction register (PDR) and port mode register (PMR) for the input port pin to switch it to operate as a general output port pin, and the port output data register (PODR) to select output of the non-active level.
- [9] Stop count operation by setting the TSTR register.
- [10] Set normal mode.
- [11] Initialize the pins with the TIOR register.
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

(6) Operation When Error Occurs in PWM Mode 1 and Operation is Restarted in PWM mode 1 Figure 19.73 shows a case in which an error occurs in PWM mode 1 and operation is restarted in PWM mode 1 after resetting.



Figure 19.73 Error Occurrence in PWM Mode 1, Recovery in PWM Mode 1

- [1] to [9] are the same as in Figure 19.72.
- [10] This step is not necessary when restarting in PWM mode 1.
- [11] Initialize the pins with the TIOR register. (In PWM mode 1, a waveform is not output on the MTIOCnB (MTIOCnD) pins. If a level is to be output, make the required general output port settings in the I/O port's port direction register (PDR) and port output data register (PODR).)
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

## (7) Operation When Error Occurs in PWM Mode 1 and Operation is Restarted in PWM mode 2 Figure 19.74 shows a case in which an error occurs in PWM mode 1 and operation is restarted in PWM mode 2 after re-



Figure 19.74 Error Occurrence in PWM Mode 1, Recovery in PWM Mode 2

- [1] to [9] are the same as in Figure 19.72.
- [10] Set PWM mode 2.

setting.

- [11] Initialize the pins with the TIOR register. (In PWM mode 2, a waveform is not output on the cycle register pins. If a level is to be output, make the required general output port settings in the I/O port's port direction register (PDR) and port output data register (PODR).)
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.



### (8) Operation When Error Occurs in PWM Mode 1 and Operation is Restarted in Phase Counting Mode

Figure 19.75 shows a case in which an error occurs in PWM mode 1 and operation is restarted in phase counting mode after re-setting.



Figure 19.75 Error Occurrence in PWM Mode 1, Recovery in Phase Counting Mode

- [1] to [9] are the same as in Figure 19.72.
- [10] Set the phase counting mode.
- [11] Initialize the pins with the TIOR register.
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13]Restart operation by setting the TSTR register.

## (9) Operation When Error Occurs in PWM Mode 2 and Operation is Restarted in Normal Mode Figure 19.76 shows a case in which an error occurs in PWM mode 2 and operation is restarted in normal mode after resetting.



Figure 19.76 Error Occurrence in PWM Mode 2, Recovery in Normal Mode

- [1] After a reset, the MTU output goes low and the ports enter high-impedance state.
- [2] Set PWM mode 2.
- [3] Initialize the pins with the TIOR register. (In the example, the initial output is a high level, and a low level is output on compare match occurrence. In PWM mode 2, the cycle register pins are not initialized. In the example, MTIOCnA is the cycle register.)
- [4] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [5] Start count operation by setting the TSTR register.
- [6] Output goes low on compare match occurrence.
- [7] An error occurs.
- [8] Use the port direction register (PDR) and port mode register (PMR) for the input port pin to switch it to operate as a general output port pin, and the port output data register (PODR) to select output of the non-active level.
- [9] Stop count operation by setting the TSTR register.
- [10] Set normal mode.
- [11] Initialize the pins with the TIOR register.
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

### (10) Operation When Error Occurs in PWM Mode 2 and Operation is Restarted in PWM Mode 1

Figure 19.77 shows a case in which an error occurs in PWM mode 2 and operation is restarted in PWM mode 1 after resetting.



Figure 19.77 Error Occurrence in PWM Mode 2, Recovery in PWM Mode 1

- [1] to [9] are the same as in Figure 19.76.
- [10] Set PWM mode 1.
- [11] Initialize the pins with the TIOR register. (In PWM mode 1, a waveform is not output on the MTIOCnB (MTIOCnD) pins. If a level is to be output, make the required general output port settings in the I/O port's port direction register (PDR) and port output data register (PODR).)
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

### (11) Operation When Error Occurs in PWM Mode 2 and Operation is Restarted in PWM Mode 2

Figure 19.78 shows a case in which an error occurs in PWM mode 2 and operation is restarted in PWM mode 2 after resetting.



Figure 19.78 Error Occurrence in PWM Mode 2, Recovery in PWM Mode 2

- [1] to [9] are the same as in Figure 19.76.
- [10] This step is not necessary when restarting in PWM mode 2.
- [11] Initialize the pins with the TIOR register. (In PWM mode 2, a waveform is not output on the cycle register pins. If a level is to be output, make the required general output port settings in the I/O port's port direction register (PDR) and port output data register (PODR).)
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.



### (12) Operation When Error Occurs in PWM Mode 2 and Operation is Restarted in Phase Counting Mode

Figure 19.79 shows a case in which an error occurs in PWM mode 2 and operation is restarted in phase counting mode after re-setting.



Figure 19.79 Error Occurrence in PWM Mode 2, Recovery in Phase Counting Mode

- [1] to [9] are the same as in Figure 19.76.
- [10] Set the phase counting mode.
- [11] Initialize the pins with the TIOR register.
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

### (13) Operation When Error Occurs in Phase Counting Mode and Operation is Restarted in Normal Mode

Figure 19.80 shows a case in which an error occurs in phase counting mode and operation is restarted in normal mode after re-setting.



Figure 19.80 Error Occurrence in Phase Counting Mode, Recovery in Normal Mode

- [1] After a reset, the MTU output goes low and the ports enter high-impedance state.
- [2] Set phase counting mode.
- [3] Initialize the pins with the TIOR register. (In the example, the initial output is a high level, and a low level is output on compare match occurrence.)
- [4] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [5] Start count operation by setting the TSTR register.
- [6] Output goes low on compare match occurrence.
- [7] An error occurs.
- [8] Use the port direction register (PDR) and port mode register (PMR) for the input port pin to switch it to operate as a general output port pin, and the port output data register (PODR) to select output of the non-active level.
- [9] Stop count operation by setting the TSTR register.
- [10] Set normal mode.
- [11] Initialize the pins with the TIOR register.
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

### (14) Operation When Error Occurs in Phase Counting Mode and Operation is Restarted in PWM Mode 1

Figure 19.81 shows a case in which an error occurs in phase counting mode and operation is restarted in PWM mode 1 after re-setting.



Figure 19.81 Error Occurrence in Phase Counting Mode, Recovery in PWM Mode 1

- [1] to [9] are the same as in Figure 19.80.
- [10] Set PWM mode 1.
- [11] Initialize the pins with the TIOR register. (In PWM mode 1, a waveform is not output on the MTIOCnB (MTIOCnD) pins. If a level is to be output, make the required general output port settings in the I/O port's port direction register (PDR) and port output data register (PODR).)
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

### (15) Operation When Error Occurs in Phase Counting Mode and Operation is Restarted in PWM Mode 2

Figure 19.82 shows a case in which an error occurs in phase counting mode and operation is restarted in PWM mode 2 after re-setting.



Figure 19.82 Error Occurrence in Phase Counting Mode, Recovery in PWM Mode 2

- [1] to [9] are the same as in Figure 19.80.
- [10] Set PWM mode 2.
- [11] Initialize the pins with the TIOR register. (In PWM mode 1, a waveform is not output on the MTIOCnB (MTIOCnD) pins. If a level is to be output, make the required general output port settings in the I/O port's port direction register (PDR) and port output data register (PODR).)
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.

### (16) Operation When Error Occurs in Phase Counting Mode and Operation is Restarted in Phase Counting Mode

Figure 19.83 shows a case in which an error occurs in phase counting mode and operation is restarted in phase counting mode after re-setting.



Figure 19.83 Error Occurrence in Phase Counting Mode, Recovery in Phase Counting Mode

- [1] to [9] are the same as in Figure 19.80.
- [10] This step is not necessary when restarting in phase counting mode.
- [11] Initialize the pins with the TIOR register.
- [12] Use the MPC and the port mode register (PMR) for the I/O port to set up MTU output.
- [13] Restart operation by setting the TSTR register.



### 20. Compare Match Timer (CMT)

This MCU has an on-chip compare match timer (CMT) unit (unit 0) consisting of a two-channel 16-bit timer (i.e., a total of two channels). The CMT has a 16-bit counter, and can generate interrupts at set intervals. In this section, "PCLK" is used to refer to PCLKB.

### 20.1 Overview

Table 20.1 lists the specifications for the CMT.

Figure 20.1 shows a block diagram of the CMT (unit 0). A two-channel CMT constitutes a unit.

Table 20.1 CMT Specifications

| Item                           | Description                                                                                                                 |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| Count clocks                   | Four frequency dividing clocks     One clock from PCLK/8, PCLK/32, PCLK/128, and PCLK/512 can be selected for each channel. |
| Interrupt                      | A compare match interrupt can be requested for each channel.                                                                |
| Low power consumption function | Module stop state can be set.                                                                                               |



Figure 20.1 CMT (Unit 0) Block Diagram

### 20.2 Register Descriptions

### 20.2.1 Compare Match Timer Start Register 0 (CMSTR0)

Address(es): 0008 8000h



| Bit       | Symbol | Bit Name      | Description                                                                               | R/W |
|-----------|--------|---------------|-------------------------------------------------------------------------------------------|-----|
| b0        | STR0   | Count Start 0 | <ul><li>0: CMT0.CMCNT count is stopped.</li><li>1: CMT0.CMCNT count is started.</li></ul> | R/W |
| b1        | STR1   | Count Start 1 | 0: CMT1.CMCNT count is stopped. 1: CMT1.CMCNT count is started.                           | R/W |
| b15 to b2 | 2 —    | Reserved      | These bits are read as 0. The write value should be 0.                                    | R/W |

### 20.2.2 Compare Match Timer Control Register (CMCR)

Address(es): CMT0.CMCR 0008 8002h, CMT1.CMCR 0008 8008h



x: Undefined

| Bit       | Symbol   | Bit Name                          | Description                                                                        | R/W |
|-----------|----------|-----------------------------------|------------------------------------------------------------------------------------|-----|
| b1, b0    | CKS[1:0] | Clock Select                      | b1 b0<br>0 0: PCLK/8<br>0 1: PCLK/32<br>1 0: PCLK/128<br>1 1: PCLK/512             | R/W |
| b5 to b2  | _        | Reserved                          | These bits are read as 0. The write value should be 0.                             | R/W |
| b6        | CMIE     | Compare Match Interrupt<br>Enable | Compare match interrupt (CMIn) disabled     Compare match interrupt (CMIn) enabled | R/W |
| b7        | _        | Reserved                          | This bit is read as undefined. The write value should be 1.                        | R/W |
| b15 to b8 | _        | Reserved                          | These bits are read as 0. The write value should be 0.                             | R/W |

#### CKS[1:0] Bits (Clock Select)

These bits select the count source from four frequency dividing clocks obtained by dividing the peripheral module clock (PCLK).

When the CMSTR0.STRn (n = 0, 1) bit is set to 1, the CMCNT counter starts counting up on the clock selected with the CKS[1:0] bits.

### **CMIE Bit (Compare Match Interrupt Enable)**

The CMIE bit enables or disables compare match interrupt (CMIn) (n = 0, 1) generation when the CMCNT counter and the CMCOR register values match.



### 20.2.3 Compare Match Counter (CMCNT)

Address(es): CMT0.CMCNT 0008 8004h, CMT1.CMCNT 0008 800Ah



The CMCNT counter is a readable/writable up-counter.

When an frequency dividing clock is selected by the CMCR.CKS[1:0] bits and the CMSTR0.STRn (n = 0, 1) bit is set to 1, the CMCNT counter starts counting up using the selected clock.

When the value in the CMCNT counter and the value in the CMCOR register match, the CMCNT counter is set to 0000h. At the same time, a compare match interrupt (CMIn) (n = 0, 1) is generated.

### 20.2.4 Compare Match Constant Register (CMCOR)

Address(es): CMT0.CMCOR 0008 8006h, CMT1.CMCOR 0008 800Ch



The CMCOR register is a readable/writable register to set a value for compare match with the CMCNT counter.

### 20.3 Operation

### 20.3.1 Periodic Count Operation

When an frequency dividing clock is selected by the CMCR.CKS[1:0] bits and the CMSTR0.STRn (n = 0, 1) bit is set to 1, the CMCNT counter starts counting up using the selected clock.

When the value in the counter and the value in the register match, a compare match interrupt (CMIn) (n = 0,1) is generated. The CMCNT counter then starts counting up again from 0000h. Figure 20.2 shows the operation of the CMCNT counter.



Figure 20.2 CMCNT Counter Operation

### 20.3.2 CMCNT Count Timing

As the count clock to be input to the CMCNT counter, one of four frequency dividing clocks (PCLK/8, PCLK/32, PCLK/128, and PCLK/512) obtained by dividing the peripheral module clock (PCLK) can be selected with the CMCR.CKS[1:0] bits. Figure 20.3 shows the timing of the CMCNT counter.



Figure 20.3 CMCNT Count Timing

### 20.4 Interrupts

### 20.4.1 Interrupt Sources

The CMT has channels and each of them to which a different vector address is allocated has a compare match interrupt (CMIn) (n = 0, 1). When a compare match interrupt occurs, the corresponding interrupt request is output.

When the interrupt request is used to generate a CPU interrupt, the priority of channels can be changed by the interrupt controller settings. For details, see section 14, Interrupt Controller (ICUb).

Table 20.2 CMT Interrupt Sources

| Name | Interrupt Sources     | DTC Activation |
|------|-----------------------|----------------|
| CMI0 | Compare match in CMT0 | Possible       |
| CMI1 | Compare match in CMT1 | Possible       |

### 20.4.2 Timing of Compare Match Interrupt Generation

When the CMCNT counter and the CMCOR register match, a compare match interrupt (CMIn) (n = 0, 1) is generated. A compare match signal is generated at the last state in which the values match (the timing when the CMCNT counter updates the matched count value). That is, after a match between the CMCOR register and the CMCNT counter, the compare match signal is not generated until the next the CMCNT counter input clock.

Figure 20.4 shows the timing of a compare match interrupt.



Figure 20.4 Timing of a Compare Match Interrupt

### 20.5 Usage Notes

### 20.5.1 Setting the Module Stop Function

The CMT can be enabled or disabled using the module stop control register. After a reset, the CMT is in the module stop state. The registers can be accessed by releasing the module stop state. For details, refer to section 11, Low Power Consumption.

### 20.5.2 Conflict between CMCNT Counter Writing and Compare Match

When the compare match signal is generated while writing to the CMCNT counter, clearing the CMCNT counter has priority over writing to it. In this case, the CMCNT counter is not written to. Figure 20.5 shows the timing to clear the CMCNT counter.



Figure 20.5 Conflict between CMCNT Counter Writing and Compare Match

### 20.5.3 Conflict between CMCNT Counter Writing and Incrementing

If writing to the counter and the incrementing conflict, the writing has priority over the incrementing. Figure 20.6 shows the timing to write the CMCNT counter.



Figure 20.6 Conflict between CMCNT Counter Writing and Incrementing

### 21. Realtime Clock (RTCA)

In this section, "PCLK" is used to refer to PCLKB.

#### 21.1 Overview

The RTC has two types of counting modes: calendar count mode and binary count mode. They are used by switching the register settings.

For calendar count mode, the RTC has a 100 year calendar from 2000 to 2099 and automatically adjusts dates for leap years.

For binary count mode, the RTC does not count in terms of years, months, dates, day-of-week, hours, or minutes; it counts seconds, and retains the information as a serial value. This mode can be used for calendars other than the Gregorian calendar.

The RTC uses the 128-Hz clock which is acquired by the count source divided by the prescaler as the basic clock. Year, month, date, day-of-week, a.m./p.m. (in 12-hour mode), hour, minute, second, or 32-bit binary is counted in 1/128 second units.

Table 21.1 lists the specifications of the RTC, Figure 21.1 shows a block diagram of the RTC, and Table 21.2 shows the pin configuration of the RTC.

Table 21.1 RTC Specifications

| Item                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Count mode                   | Calendar count mode/binary count mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Count source*1               | Sub-clock (XCIN)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Clock and calendar functions | <ul> <li>Calendar count mode Year, month, date, day-of-week, hour, minute, second are counted, BCD display 12 hours/24 hours mode switching function 30 seconds adjustment function (a number less than 30 is rounded down to 00 seconds, and 30 seconds or more are rounded up to one minute) Automatic adjustment function for leap years</li> <li>Binary count mode Count seconds in 32 bits, binary display</li> <li>Common to both modes Start/stop function The sub-second digit is displayed in binary units (1 Hz, 2 Hz, 4 Hz, 8 Hz, 16 Hz, 32 Hz, or 64 Hz). Clock error correction function Clock (1 Hz/64 Hz) output</li> </ul>                                                                                                                                                                                                     |
| Interrupts                   | <ul> <li>Alarm interrupt (ALM) As an alarm interrupt condition, selectable which of the below is compared with: Calendar count mode: Year, month, date, day-of-week, hour, minute, or second can be selected Binary count mode: Each bit of the 32-bit binary counter</li> <li>Periodic interrupt (PRD) 2 seconds, 1 second, 1/2 second, 1/4 second, 1/8 second, 1/16 second, 1/32 second, 1/64 second, or 1/256 second can be selected as an interrupt period.</li> <li>Carry interrupt (CUP) An interrupt is generated at either of the following timings: - When a carry from the 64-Hz counter to the second counter is generated When the 64-Hz counter is changed and the R64CNT register is read at the same time.</li> <li>Recovery from software standby mode can be performed by an alarm interrupt or periodic interrupt</li> </ul> |

Note 1. Satisfy the frequency of the peripheral module clock (PCLKB) ≥ the frequency of the count source clock.



Figure 21.1 Block Diagram of RTC

Table 21.2 Pin Configuration of RTC

| Pin Name | I/O    | Function                                          |
|----------|--------|---------------------------------------------------|
| XCIN     | Input  | Connect a 32.768-kHz crystal to these pins.       |
| XCOUT    | Output | _                                                 |
| RTCOUT   | Output | This pin is used to output a 1-Hz/64-Hz waveform. |
|          |        |                                                   |

### 21.2 Register Descriptions

When writing to or reading from RTC registers, do so in accordance with section 21.5.5, Notes When Writing to and Reading from Registers.

If the value in an RTC register after a reset is given as x (undefined bits) in the list, it is not initialized by a reset. When RTC enters the reset state or a low power consumption state during counting operations (i.e. while the RCR2.START bit is 1), the year, month, day of the week, date, hours, minutes, seconds, and 64-Hz counters continue to operate. Note that a reset generated during writing to or updating of a register might destroy the register value. In addition, do not allow the chip to enter software standby mode immediately after setting any of these registers. For details, refer to section 21.5.4, Transitions to Low Power Consumption Modes after Setting Registers.

### 21.2.1 64-Hz Counter (R64CNT)

Address(es): 0008 C400h



x: Undefined

| Bit | Symbol | Bit Name | Description                                                        | R/W |
|-----|--------|----------|--------------------------------------------------------------------|-----|
| b0  | F64HZ  | 64 Hz    | Indicate the state between 1 Hz and 64 Hz of the sub-second digit. | R   |
| b1  | F32HZ  | 32 Hz    |                                                                    | R   |
| b2  | F16HZ  | 16 Hz    |                                                                    | R   |
| b3  | F8HZ   | 8 Hz     |                                                                    | R   |
| b4  | F4HZ   | 4 Hz     |                                                                    | R   |
| b5  | F2HZ   | 2 Hz     |                                                                    | R   |
| b6  | F1HZ   | 1 Hz     |                                                                    | R   |
| b7  | _      | Reserved | This bit is read as 0. Writing to this bit has no effect.          | R   |

The R64CNT counter is used in both calendar count mode and in binary count mode.

The 64-Hz counter (R64CNT) generates the period for a second by counting up periods of the 128-Hz clock.

The state in the sub-second range can be confirmed by reading this counter.

This counter is set to 00h by an RTC software reset or executing 30-second adjustment.

To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

### 21.2.2 Second Counter (RSECCNT)/Binary Counter 0 (BCNT0)

### (1) In calendar count mode:

Address(es): RSECCNT 0008 C402h



x: Undefined

| Bit      | Symbol     | Bit Name        | Description                                                                               | R/W |
|----------|------------|-----------------|-------------------------------------------------------------------------------------------|-----|
| b3 to b0 | SEC1[3:0]  | 1-Second Count  | Counts from 0 to 9 every second. When a carry is generated, 1 is added to the tens place. | R/W |
| b6 to b4 | SEC10[2:0] | 10-Second Count | Counts from 0 to 5 for 60-second counting.                                                | R/W |
| b7       | _          | Reserved        | Set this bit to 0. It is read as the set value.                                           | R/W |

The RSECCNT counter is used for setting and counting the BCD-coded second value. It counts carries generated once per second in the 64-Hz counter.

The setting range is decimal 00 to 59. The RTC will not operate normally if any other value is set. Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2.

To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

#### (2) In binary count mode:

Address(es): BCNT0 0008 C402h



The BCNT0 counter is a readable/writable 32-bit binary counter b7 to b0.

The 32-bit binary counter performs count operation by a carry generating for each second of the 64-Hz counter.

Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2.

To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

## 21.2.3 Minute Counter (RMINCNT)/Binary Counter 1 (BCNT1)

### (1) In calendar count mode:

Address(es): RMINCNT 0008 C404h



x: Undefined

| Bit      | Symbol     | Bit Name        | Description                                                                               | R/W |
|----------|------------|-----------------|-------------------------------------------------------------------------------------------|-----|
| b3 to b0 | MIN1[3:0]  | 1-Minute Count  | Counts from 0 to 9 every minute. When a carry is generated, 1 is added to the tens place. | R/W |
| b6 to b4 | MIN10[2:0] | 10-Minute Count | Counts from 0 to 5 for 60-minute counting.                                                | R/W |
| b7       | _          | Reserved        | Set this bit to 0. It is read as the set value.                                           | R/W |

The RMINCNT counter is used for setting and counting the BCD-coded minute value. It counts carries generated once per minute in the second counter.

A value from 00 through 59 (in BCD) can be specified; if a value outside of this range is specified, the RTC does not operate correctly. Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2.

To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

### (2) In binary count mode:

Address(es): BCNT1 0008 C404h



x: Undefined

The BCNT1 counter is a readable/writable 32-bit binary counter b15 to b8.

The 32-bit binary counter performs count operation by a carry generating for each second of the 64-Hz counter. Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2. To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

## 21.2.4 Hour Counter (RHRCNT)/Binary Counter 2 (BCNT2)

### (1) In calendar count mode:

Address(es): RHRCNT 0008 C406h



x: Undefined

| Bit      | Symbol    | Bit Name      | Description                                                                                | R/W |
|----------|-----------|---------------|--------------------------------------------------------------------------------------------|-----|
| b3 to b0 | HR1[3:0]  | 1-Hour Count  | Counts from 0 to 9 once per hour. When a carry is generated, 1 is added to the tens place. | R/W |
| b5, b4   | HR10[1:0] | 10-Hour Count | Counts from 0 to 2 once per carry from the ones place.                                     | R/W |
| b6       | PM        | PM            | Time Counter Setting for a.m./p.m. 0: a.m. 1: p.m.                                         | R/W |
| b7       | _         | Reserved      | Set this bit to 0. It is read as the set value.                                            | R/W |

The RHRCNT counter is used for setting and counting the BCD-coded hour value. It counts carries generated once per hour in the minute counter.

The specifiable time differs according to the setting in the hours mode bit (RCR2.HR24).

When the RCR2.HR24 bit is 0: From 00 to 11 (in BCD)

When the RCR2.HR24 bit is 1: From 00 to 23 (in BCD)

If a value outside of this range is specified, the RTC does not operate correctly. Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2.

The PM bit is only enabled when the RCR2.HR24 bit is 0. Otherwise, the setting in the PM bit has no effect.

To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

#### (2) In binary count mode:

Address(es): BCNT2 0008 C406h



The BCNT2 counter is a readable/writable 32-bit binary counter b23 to b16.

The 32-bit binary counter performs count operation by a carry generating for each second of the 64-Hz counter.

Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2.

To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

## 21.2.5 Day-of-Week Counter (RWKCNT)/Binary Counter 3 (BCNT3)

#### (1) In calendar count mode:

Address(es): RWKCNT 0008 C408h



x: Undefined

| Bit      | Symbol    | Bit Name             | Description                                                                                                                               | R/W |
|----------|-----------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b2 to b0 | DAYW[2:0] | Day-of-Week Counting | b2 b0 0 0 0: Sunday 0 0 1: Monday 0 1 0: Tuesday 0 1 1: Wednesday 1 0 0: Thursday 1 0 1: Friday 1 1 0: Saturday 1 1 1: Setting Prohibited | R/W |
| b7 to b3 | _         | Reserved             | Set these bits to 0. They are read as the set value.                                                                                      | R/W |

The RWKCNT counter is used for setting and counting in the coded day-of-week value. It counts carries generated once per day in the hour counter.

A value from 0 through 6 can be specified; if a value outside of this range is specified, the RTC does not operate correctly. Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2.

To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

### (2) In binary count mode:

Address(es): BCNT3 0008 C408h



x: Undefined

The BCNT3 counter is a readable/writable 32-bit binary counter b31 to b24.

The 32-bit binary counter performs count operation by a carry generating for each second of the 64-Hz counter. Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2. To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

## 21.2.6 Date Counter (RDAYCNT)

Address(es): 0008 C40Ah



x: Undefined

| Bit      | Symbol      | Bit Name     | Description                                                                               | R/W |
|----------|-------------|--------------|-------------------------------------------------------------------------------------------|-----|
| b3 to b0 | DATE1[3:0]  | 1-Day Count  | Counts from 0 to 9 once per day. When a carry is generated, 1 is added to the tens place. | R/W |
| b5, b4   | DATE10[1:0] | 10-Day Count | Counts from 0 to 3 once per carry from the ones place.                                    | R/W |
| b7, b6   | _           | Reserved     | These bits are read as 0. The write value should be 0.                                    | R/W |

The RDAYCNT counter is used in calendar count mode.

RDAYCNT is used for setting and counting the BCD-coded date value. It counts carries generated once per day in the hour counter. The count operation depends on the month and whether the year is a leap year.

Leap years are determined according to whether the year counter (RYRCNT) value is divisible by 400, 100, and 4. A value from 01 through 31 (in BCD) can be specified; if a value outside of this range is specified, the RTC does not operate correctly. (When specifying a value, note that the range of specifiable days depends on the month and whether the year is a leap year.) Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2.

To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

## 21.2.7 Month Counter (RMONCNT)

Address(es): 0008 C40Ch



x: Undefined

| Bit      | Symbol    | Bit Name       | Description                                                                                 | R/W |
|----------|-----------|----------------|---------------------------------------------------------------------------------------------|-----|
| b3 to b0 | MON1[3:0] | 1-Month Count  | Counts from 0 to 9 once per month. When a carry is generated, 1 is added to the tens place. | R/W |
| b4       | MON10     | 10-Month Count | Counts from 0 to 1 once per carry from the ones place.                                      | R/W |
| b7 to b5 | _         | Reserved       | These bits are read as 0. The write value should be 0.                                      | R/W |

The RMONCNT counter is used in calendar count mode.

RMONCNT is used for setting and counting the BCD-coded month value. It counts carries generated once per month in the date counter.

A value from 01 through 12 (in BCD) can be specified; if a value outside of this range is specified, the RTC does not operate correctly. Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2.

To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

## 21.2.8 Year Counter (RYRCNT)

Address(es): 0008 C40Eh



x: Undefined

| Bit       | Symbol    | Bit Name      | Description                                                                                                                       | R/W |
|-----------|-----------|---------------|-----------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0  | YR1[3:0]  | 1-Year Count  | Counts from 0 to 9 once per year. When a carry is generated, 1 is added to the tens place.                                        | R/W |
| b7 to b4  | YR10[3:0] | 10-Year Count | Counts from 0 to 9 once per carry from ones place. When a carry is generated in the tens place, 1 is added to the hundreds place. | R/W |
| b15 to b8 | _         | Reserved      | These bits are read as 0. The write value should be 0.                                                                            | R/W |

The RYRCNT counter is used in calendar count mode.

RYRCNT is used for setting and counting the BCD-coded year value. It counts carries generated once per year in the month counter.

A value from 00 through 99 (in BCD) can be specified; if a value outside of this range is specified, the RTC does not operate correctly. Before writing to this register, be sure to stop the count operation through the setting of the START bit in RCR2.

To read this counter, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.

# 21.2.9 Second Alarm Register (RSECAR)/Binary Counter 0 Alarm Register (BCNT0AR)

#### (1) In calendar count mode:

Address(es): RSECAR 0008 C410h



x: Undefined

| Bit      | Symbol     | Bit Name   | Description                                                                                                                           | R/W |
|----------|------------|------------|---------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0 | SEC1[3:0]  | 1 Second   | Value for the ones place of seconds                                                                                                   | R/W |
| b6 to b4 | SEC10[2:0] | 10 Seconds | Value for the tens place of seconds                                                                                                   | R/W |
| b7       | ENB        | ENB        | O: The register value is not compared with the RSECCNT counter value.  The register value is compared with the RSECCNT counter value. | R/W |

RSECAR is an alarm register corresponding to the BCD-coded second counter RSECCNT. When the ENB bit is set to 1, the RSECAR value is compared with the RSECCNT value. From among the alarm registers (RSECAR, RMINAR, RHRAR, RWKAR, RDAYAR, RMONAR, and RYRAREN), only those selected with the ENB bits set to 1 are compared with the corresponding counters. When the respective values all match, the IR flag corresponding to the ALM interrupt is set to 1.

RSECAR values from 00 through 59 (in BCD) can be specified; if a value outside of this range is specified, the RTC does not operate correctly.

This register is set to 00h by an RTC software reset.

#### (2) In binary count mode:

Address(es): BCNT0AR 0008 C410h



The BCNT0AR counter is a readable/writable alarm register corresponding to 32-bit binary counter b7 to b0. This register is set to 00h by an RTC software reset.

## 21.2.10 Minute Alarm Register (RMINAR)/Binary Counter 1 Alarm Register (BCNT1AR)

### (1) In calendar count mode:

Address(es): RMINAR 0008 C412h



x: Undefined

| Bit      | Symbol     | Bit Name   | Description                                                                                                                           | R/W |
|----------|------------|------------|---------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0 | MIN1[3:0]  | 1 Minute   | Value for the ones place of minutes                                                                                                   | R/W |
| b6 to b4 | MIN10[2:0] | 10 Minutes | Value for the tens place of minutes                                                                                                   | R/W |
| b7       | ENB        | ENB        | O: The register value is not compared with the RMINCNT counter value.  The register value is compared with the RMINCNT counter value. | R/W |

RMINAR is an alarm register corresponding to the BCD-coded minute counter RMINCNT. When the ENB bit is set to 1, the RMINAR value is compared with the RMINCNT value. From among the alarm registers (RSECAR, RMINAR, RHRAR, RWKAR, RDAYAR, RMONAR, and RYRAREN), only those selected with the ENB bits set to 1 are compared with the corresponding counters. When the respective values all match, the IR flag corresponding to the ALM interrupt is set to 1.

RMINAR values from 00 through 59 (in BCD) can be specified; if a value outside of this range is specified, the RTC does not operate correctly.

This register is set to 00h by an RTC software reset.

## (2) In binary count mode:

Address(es): BCNT1AR 0008 C412h



x: Undefined

The BCNT1AR counter is a readable/writable alarm register corresponding to 32-bit binary counter b15 to b8. This register is set to 00h by an RTC software reset.

## 21.2.11 Hour Alarm Register (RHRAR)/Binary Counter 2 Alarm Register (BCNT2AR)

### (1) In calendar count mode:

Address(es): RHRAR 0008 C414h



x: Undefined

| Bit      | Symbol    | Bit Name | Description                                                                                                                            | R/W |
|----------|-----------|----------|----------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0 | HR1[3:0]  | 1 Hour   | Value for the ones place of hours                                                                                                      | R/W |
| b5, b4   | HR10[1:0] | 10 Hours | Value for the tens place of hours                                                                                                      | R/W |
| b6       | PM        | PM       | Time Alarm Setting for a.m./p.m. 0: a.m. 1: p.m.                                                                                       | R/W |
| b7       | ENB       | ENB      | O: The register value is not compared with the RHRCNT counter value.  1: The register value is compared with the RHRCNT counter value. | R/W |

RHRAR is an alarm register corresponding to the BCD-coded hour counter RHRCNT. When the ENB bit is set to 1, the RHRAR value is compared with the RHRCNT value. From among the alarm registers (RSECAR, RMINAR, RHRAR, RWKAR, RDAYAR, RMONAR, and RYRAREN), only those selected with the ENB bits set to 1 are compared with the corresponding counters. When the respective values all match, the IR flag corresponding to the ALM interrupt is set to 1. The specifiable time differs according to the setting in the hours mode bit (RCR2.HR24).

When the RCR2.HR24 bit is 0: From 00 to 11 (in BCD)

When the RCR2.HR24 bit is 1: From 00 to 23 (in BCD)

If a value outside of this range is specified, the RTC does not operate correctly.

When the RCR2.HR24 bit is 0, be sure to set the PM bit.

When the RCR2.HR24 bit is 1, the setting in the PM bit has no effect.

This register is set to 00h by an RTC software reset.

#### (2) In binary count mode:

Address(es): BCNT2AR 0008 C414h



The BCNT2AR counter is a readable/writable alarm register corresponding to 32-bit binary counter b23 to b16. This register is set to 00h by an RTC software reset.

# 21.2.12 Day-of-Week Alarm Register (RWKAR)/Binary Counter 3 Alarm Register (BCNT3AR)

#### (1) In calendar count mode:

Address(es): RWKAR 0008 C416h



x: Undefined

| Bit      | Symbol    | Bit Name            | Description                                                                                                                               | R/W |
|----------|-----------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b2 to b0 | DAYW[2:0] | Day-of-Week Setting | b2 b0 0 0 0: Sunday 0 0 1: Monday 0 1 0: Tuesday 0 1 1: Wednesday 1 0 0: Thursday 1 0 1: Friday 1 1 0: Saturday 1 1 1: Setting Prohibited | R/W |
| b6 to b3 | _         | Reserved            | Set these bits to 0. They are read as the set value.                                                                                      | R/W |
| b7       | ENB       | ENB                 | O: The register value is not compared with the RWKCNT counter value.  1: The register value is compared with the RWKCNT counter value.    | R/W |

RWKAR is an alarm register corresponding to the coded day-of-week counter RWKCNT. When the ENB bit is set to 1, the RWKAR value is compared with the RWKCNT value. From among the alarm registers (RSECAR, RMINAR, RHRAR, RWKAR, RDAYAR, RMONAR, and RYRAREN), only those selected with the ENB bits set to 1 are compared with the corresponding counters. When the respective values all match, the IR flag corresponding to the ALM interrupt is set to 1.

RWKAR values from 0 through 6 (in BCD) can be specified; if a value outside of this range is specified, the RTC does not operate correctly.

This register is set to 00h by an RTC software reset.

#### (2) In binary count mode:

Address(es): BCNT3AR 0008 C416h



x: Undefined

The BCNT3AR counter is a readable/writable alarm register corresponding to 32-bit binary counter b31 to b24. This register is set to 00h by an RTC software reset.

# 21.2.13 Date Alarm Register (RDAYAR)/Binary Counter 0 Alarm Enable Register (BCNT0AER)

#### (1) In calendar count mode:

Address(es): RDAYAR 0008 C418h



x: Undefined

| Bit      | Symbol      | Bit Name | Description                                                                                                                           | R/W |
|----------|-------------|----------|---------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0 | DATE1[3:0]  | 1 Day    | Value for the ones place of days                                                                                                      | R/W |
| b5, b4   | DATE10[1:0] | 10 Days  | Value for the tens place of days                                                                                                      | R/W |
| b6       | _           | Reserved | Set this bit to 0. It is read as the set value.                                                                                       | R/W |
| b7       | ENB         | ENB      | The register value is not compared with the RDAYCNT counter value.     The register value is compared with the RDAYCNT counter value. | R/W |

RDAYAR is an alarm register corresponding to the BCD-coded date counter RDAYCNT. When the ENB bit is set to 1, the RDAYAR value is compared with the RDAYCNT value. From among the alarm registers (RSECAR, RMINAR, RHRAR, RWKAR, RDAYAR, RMONAR, and RYRAREN), only those selected with the ENB bits set to 1 are compared with the corresponding counters. When the respective values all match, the IR flag corresponding to the ALM interrupt is set to 1.

RDAYAR values from 01 through 31 (in BCD) can be specified; if a value outside of this range is specified, the RTC does not operate correctly.

This register is set to 00h by an RTC software reset.

#### (2) In binary count mode:

Address(es): BCNT0AER 0008 C418h



x: Undefined

The BCNT0AER register is a readable/writable register for setting the alarm enable corresponding to 32-bit binary counter b7 to b0. Among the ENB[31:0] bits, the binary counter (BCNT[31:0]) corresponding to the bits which are set to 1 and the binary alarm register (BCNTAR[31:0]) are compared, and when all match, the IR flag corresponding to the ALM interrupt becomes 1.

This register is set to 00h by an RTC software reset.

# 21.2.14 Month Alarm Register (RMONAR)/Binary Counter 1 Alarm Enable Register (BCNT1AER)

#### (1) In calendar count mode:

Address(es): RMONAR 0008 C41Ah



x: Undefined

| Bit      | Symbol    | Bit Name  | Description                                                                                                                              | R/W |
|----------|-----------|-----------|------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0 | MON1[3:0] | 1 Month   | Value for the ones place of months                                                                                                       | R/W |
| b4       | MON10     | 10 Months | Value for the tens place of months                                                                                                       | R/W |
| b6, b5   | _         | Reserved  | Set these bits to 0. They are read as the set value.                                                                                     | R/W |
| b7       | ENB       | ENB       | O: The register value is not compared with the RMONCNT counter value.  1: The register value is compared with the RMONCNT counter value. | R/W |

RMONAR is an alarm register corresponding to the BCD-coded month counter RMONCNT. When the ENB bit is set to 1, the RMONAR value is compared with the RMONCNT value. From among the alarm registers (RSECAR, RMINAR, RHRAR, RWKAR, RDAYAR, RMONAR, and RYRAREN), only those selected with the ENB bits set to 1 are compared with the corresponding counters. When the respective values all match, the IR flag corresponding to the ALM interrupt is set to 1.

RMONAR values from 01 through 12 (in BCD) can be specified; if a value outside of this range is specified, the RTC does not operate correctly.

This register is set to 00h by an RTC software reset.

#### (2) In binary count mode:

Address(es): BCNT1AER 0008 C41Ah



x: Undefined

The BCNT1AER register is a readable/writable register for setting the alarm enable corresponding to 32-bit binary counter b15 to b8. Among the ENB[31:0] bits, the binary counter (BCNT[31:0]) corresponding to the bits which are set to 1 and the binary alarm register (BCNTAR[31:0]) are compared, and when all match, the IR flag corresponding to the ALM interrupt becomes 1.

This register is set to 00h by an RTC software reset.

# 21.2.15 Year Alarm Register (RYRAR)/Binary Counter 2 Alarm Enable Register (BCNT2AER)

#### (1) In calendar count mode:

Address(es): RYRAR 0008 C41Ch



x: Undefined

| Bit       | Symbol    | Bit Name | Description                                            | R/W |
|-----------|-----------|----------|--------------------------------------------------------|-----|
| b3 to b0  | YR1[3:0]  | 1 Year   | Value for the ones place of years                      | R/W |
| b7 to b4  | YR10[3:0] | 10 Years | Value for the tens place of years                      | R/W |
| b15 to b8 | _         | Reserved | These bits are read as 0. The write value should be 0. | R/W |

RYRAR is an alarm register corresponding to the BCD-coded year counter RYRCNT.

RYRAR values from 00 through 99 (in BCD) can be specified; if a value outside of this range is specified, the RTC does not operate correctly.

This register is set to 0000h by an RTC software reset.

#### (2) In binary count mode:

Address(es): BCNT2AER 0008 C41Ch



x: Undefined

The BCNT2AER register is a readable/writable register for setting the alarm enable corresponding to 32-bit binary counter b23 to b16. Among the ENB[31:0] bits, the binary counter (BCNT[31:0]) corresponding to the bits which are set to 1 and the binary alarm register (BCNTAR[31:0]) are compared, and when all match, the IR flag corresponding to the ALM interrupt becomes 1.

This register is set to 0000h by an RTC software reset.

# 21.2.16 Year Alarm Enable Register (RYRAREN)/Binary Counter 3 Alarm Enable Register (BCNT3AER)

#### (1) In calendar count mode:

Address(es): RYRAREN 0008 C41Eh



x: Undefined

| Bit      | Symbol | Bit Name | Description                                                                                                                        | R/W |
|----------|--------|----------|------------------------------------------------------------------------------------------------------------------------------------|-----|
| b6 to b0 | _      | Reserved | Set these bits to 0. They are read as the set value.                                                                               | R/W |
| b7       | ENB    | ENB      | O: The register value is not compared with the RYRCNT counter value. The register value is compared with the RYRCNT counter value. | R/W |

When the ENB bit in RYRAREN is set to 1, the RYRAR value is compared with the RYRCNT value. From among the alarm registers (RSECAR, RMINAR, RHRAR, RWKAR, RDAYAR, RMONAR, and RYRAREN), only those selected with the ENB bits set to 1 are compared with the corresponding counters. When the respective values all match, the IR flag corresponding to the ALM interrupt is set to 1.

This register is set to 00h by an RTC software reset.

#### (2) In binary count mode:

Address(es): BCNT3AER 0008 C41Eh



x: Undefined

The BCNT3AER register is a readable/writable register for setting the alarm enable corresponding to 32-bit binary counter b31 to b24. Among the ENB[31:0] bits, the binary counter (BCNT[31:0]) corresponding to the bits which are set to 1 and the binary alarm register (BCNTAR[31:0]) are compared, and when all match, the IR flag corresponding to the ALM interrupt becomes 1.

This register is set to 00h by an RTC software reset.

## 21.2.17 RTC Control Register 1 (RCR1)

Address(es): 0008 C422h



x: Undefined

| Bit      | Symbol   | Bit Name                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W |
|----------|----------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | AIE      | Alarm Interrupt Enable    | O: An alarm interrupt request is disabled.     1: An alarm interrupt request is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R/W |
| b1       | CIE      | Carry Interrupt Enable    | 0: A carry interrupt request is disabled. 1: A carry interrupt request is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R/W |
| b2       | PIE      | Periodic Interrupt Enable | O: A periodic interrupt request is disabled.  1: A periodic interrupt request is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R/W |
| b3       | RTCOS    | RTCOUT Output Select      | 0: RTCOUT outputs 1 Hz. 1: RTCOUT outputs 64 Hz.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R/W |
| b7 to b4 | PES[3:0] | Periodic Interrupt Select | b7 b4 0 1 1 0: A periodic interrupt is generated every 1/256 second. 0 1 1 1: A periodic interrupt is generated every 1/128 second. 1 0 0 0: A periodic interrupt is generated every 1/64 second. 1 0 0 1: A periodic interrupt is generated every 1/32 second. 1 0 1 0: A periodic interrupt is generated every 1/16 second. 1 0 1 1: A periodic interrupt is generated every 1/16 second. 1 0 0: A periodic interrupt is generated every 1/8 second. 1 1 0 0: A periodic interrupt is generated every 1/4 second. 1 1 0 1: A periodic interrupt is generated every 1/2 second. 1 1 1 0: A periodic interrupt is generated every 1 second. 1 1 1 1: A periodic interrupt is generated every 2 seconds. Other than above: No periodic interrupts are generated. | R/W |

The RCR1 register is used in both calendar count mode and in binary count mode.

Bits AIE, PIE, and PES[3:0] are updated synchronously with the count source. When the RCR1 register is modified, check that all the bits have been updated before proceeding to the next processing.

#### **AIE Bit (Alarm Interrupt Enable)**

This bit enables or disables alarm interrupt requests.

#### **CIE Bit (Carry Interrupt Enable)**

This bit enables and disables interrupt requests when a carry to the RSECCNT/BCNT0 register occurs, or when a carry to the 64-Hz counter (R64CNT) occurs while reading the 64-Hz counter.

#### PIE Bit (Periodic Interrupt Enable)

This bit enables or disabled a periodic interrupt.

#### **RTCOS Bit (RTCOUT Output Select)**

This bit selects the RTCOUT output period. The RTCOS bit must be rewritten while count operation is stopped (the RCR2.START bit is 0) and RTCOUT output is disabled (the RCR2.RTCOE bit is 0). When the RTCOUT is output to an external pin, the RCR2.RTCOE bit must be enabled. For details on controlling I/O ports, refer to section 18.3.1, Procedure for Specifying I/O Pin Functions.

#### PES[3:0] Bits (Periodic Interrupt Select)

These bits specify the period for the periodic interrupt. A periodic interrupt is generated with the period specified by these bits.



## 21.2.18 RTC Control Register 2 (RCR2)

### (1) In calendar count mode:

Address(es): 0008 C424h



x: Undefined

| Bit | Symbol | Bit Name                              | Description                                                                                                                                                                                                                                                                                            | R/W |
|-----|--------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | START  | Start                                 | Prescaler and time counter are stopped.     Prescaler and time counter operate normally.                                                                                                                                                                                                               | R/W |
| b1  | RESET  | RTC Software Reset                    | <ul> <li>In writing</li> <li>0: Writing is invalid.</li> <li>1: The prescaler and the target registers for RTC software reset *1 are initialized</li> <li>In reading</li> <li>0: In normal time operation, or an RTC software reset has completed.</li> <li>1: During an RTC software reset</li> </ul> | R/W |
| b2  | ADJ30  | 30-Second Adjustment                  | <ul> <li>In writing</li> <li>0: Writing is invalid.</li> <li>1: 30-second adjustment is executed.</li> <li>In reading</li> <li>0: In normal time operation, or 30-second adjustment has completed.</li> <li>1: During 30-second adjustment</li> </ul>                                                  | R/W |
| b3  | RTCOE  | RTCOUT Output Enable                  | 0: RTCOUT output disabled. 1: RTCOUT output enabled.                                                                                                                                                                                                                                                   | R/W |
| b4  | AADJE  | Automatic Adjustment Enable           | O: Automatic adjustment is disabled.     Automatic adjustment is enabled.                                                                                                                                                                                                                              | R/W |
| b5  | AADJP  | Automatic Adjustment Period<br>Select | O: The RADJ.ADJ[5:0] setting value is adjusted from the count value of the prescaler every minute.  The RADJ.ADJ[5:0] setting value is adjusted from the count value of the prescaler every 10 seconds.                                                                                                | R/W |
| b6  | HR24   | Hours Mode                            | 0: The RTC operates in 12-hour mode. 1: The RTC operates in 24-hour mode.                                                                                                                                                                                                                              | R/W |
| b7  | CNTMD  | Count Mode Select                     | 0: The calendar count mode. 1: The binary count mode.                                                                                                                                                                                                                                                  | R/W |

Note 1. R64CNT, RSECAR/BCNT0AR, RMINAR/BCNT1AR, RHRAR/BCNT2AR, RWKAR/BCNT3AR, RDAYAR/BCNT0AER, RMONAR/BCNT1AER, RYRAR/BCNT2AER, RYRAREN/BCNT3AER, RADJ, RCR2.ADJ30, RCR2.AADJE, RCR2.AADJP

The RCR2 register is related to hours mode, automatic adjustment function, enabling the RTCOUT output, 30-second adjustment, RTC software reset, and controlling count operation.

#### **START Bit (Start)**

This bit stops or restarts the prescaler or time counter operation.

The START bit is updated in synchronization with the next count source. When the START bit is modified, check that the bit has been updated before proceeding to the next processing.

#### **RESET Bit (RTC Software Reset)**

This bit initializes the prescaler and registers to be reset by RTC software.

When 1 is written to the RESET bit, the initialization starts in synchronization with the count source. When the

initialization is completed, the RESET bit is automatically set to 0.

When 1 is written to the RESET bit, check that the bit is set to 0, and then make next settings.

#### **ADJ30 Bit (30-Second Adjustment)**

This bit is for 30-second adjustment.

When 1 is written to the ADJ30 bit, the RSECCNT value of 30 seconds or less is rounded down to 00 second and the value of 30 seconds or more is rounded up to 1 minute.

The 30-second adjustment is performed in synchronization with the count source. When 1 is written to this bit, the ADJ30 bit is automatically set to 0 after the 30-second adjustment is completed. In case when 1 is written to the ADJ30 bit, check that the bit is set to 0, and then make next settings.

When the 30-second adjustment is performed, the prescaler and R64CNT are also reset.

The ADJ30 bit is set to 0 by an RTC software reset.

#### **RTCOE Bit (RTCOUT Output Enable)**

This bit enables output of a 1-Hz/64-Hz clock signal from the RTCOUT pin.

Use the START bit to stop counting by the counters before changing the value of the RTCOE bit. Do not stop counting (write 0 to the START bit) and change the value of the RTCOE bit at the same time.

When RTCOUT is to be output from an external pin, enable the RTCOE bit and set up the port control for the pin.

#### **AADJE Bit (Automatic Adjustment Enable)**

This bit controls (enables or disables) automatic adjustment.

Set the plus-minus bits (RADJ.PMADJ[1:0]) to 00b (adjustment is not performed) before changing the value of the AADJE bit.

The AADJE bit is set to 0 by an RTC software reset.

#### **AADJP Bit (Automatic Adjustment Period Select)**

This bit selects the automatic-adjustment period.

Set the plus-minus bits (RADJ.PMADJ[1:0]) to 00b (adjustment is not performed) before changing the value of the AADIP bit

The AADJP bit is set to 0 by an RTC software reset.

#### **HR24 Bit (Hours Mode)**

This bit specifies whether the RTC will operate in 12- or 24-hour mode.

Use the START bit to stop counting by the counters before changing the value of the HR24 bit. Do not stop counting (write 0 to the START bit) and change the value of the HR24 bit at the same time.

#### **CNTMD Bit (Count Mode Select)**

This bit specifies whether the RTC count mode is operated in calendar count mode or in binary count mode.

When setting the count mode, execute an RTC software reset and start again from the initial settings.

This bit is updated synchronously with the count source, and its value is fixed before the RTC software reset is completed.

For details on initial settings, refer to section 21.3.1, Outline of Initial Settings of Registers after Power On.



## (2) In binary count mode:

Address(es): 0008 C424h



x: Undefined

| Bit | Symbol | Bit Name                              | Description                                                                                                                                                                                                                                                                                           | R/W |
|-----|--------|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | START  | Start                                 | <ul><li>0: The 32-bit binary counter, 64-Hz counter, and prescaler are stopped.</li><li>1: The 32-bit binary counter, 64-Hz counter, and prescaler are in normal operation.</li></ul>                                                                                                                 | R/W |
| b1  | RESET  | RTC Software Reset                    | <ul> <li>In writing</li> <li>0: Writing is invalid.</li> <li>1: The prescaler and the target registers for RTC software reset*1 are initialized</li> <li>In reading</li> <li>0: In normal time operation, or an RTC software reset has completed.</li> <li>1: During an RTC software reset</li> </ul> | R/W |
| b2  | _      | Reserved                              | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                                                   | R/W |
| b3  | RTCOE  | RTCOUT Output Enable                  | RTCOUT output disabled.     RTCOUT output enabled.                                                                                                                                                                                                                                                    | R/W |
| b4  | AADJE  | Automatic Adjustment Enable           | O: Automatic adjustment is disabled.     Automatic adjustment is enabled.                                                                                                                                                                                                                             | R/W |
| b5  | AADJP  | Automatic Adjustment Period<br>Select | O: Adds or subtracts the RADJ.ADJ[5:0] bits from the prescaler count value every 32 seconds     1: Adds or subtracts the RADJ.ADJ[5:0] bits from the prescaler count value every 8 seconds                                                                                                            | R/W |
| b6  | _      | Reserved                              | This bit is undefined. The write value should be 0.                                                                                                                                                                                                                                                   | R/W |
| b7  | CNTMD  | Count Mode Select                     | O: The calendar count mode. The binary count mode.  O: The binary count mode.                                                                                                                                                                                                                         | R/W |

Note 1. R64CNT, RSECAR/BCNT0AR, RMINAR/BCNT1AR, RHRAR/BCNT2AR, RWKAR/BCNT3AR, RDAYAR/BCNT0AER, RMONAR/BCNT1AER, RYRAR/BCNT2AER, RYRAREN/BCNT3AER, RADJ, RCR2.ADJ30, RCR2.AADJE, RCR2.AADJP

#### **START Bit (Start)**

This bit stops or restarts the prescaler or counter (clock) operation.

The START bit is updated in synchronization with the count source. When the START bit is modified, check that the bit is updated, and then make next settings.

#### **RESET Bit (RTC Software Reset)**

This bit initializes the prescaler and registers to be reset by RTC software.

When 1 is written to the RESET bit, the initialization starts in synchronization with the count source. When the initialization is completed, the RESET bit is automatically set to 0.

When 1 is written to the RESET bit, check that the bit is set to 0, and then make next settings.

#### **RTCOE Bit (RTCOUT Output Enable)**

This bit enables output of a 1-Hz/64-Hz clock signal from the RTCOUT pin.

Use the START bit to stop counting by the counters before changing the value of the RTCOE bit. Do not stop counting (write 0 to the START bit) and change the value of the RTCOE bit at the same time.

When an RTCOUT signal is to be output from an external pin, enable the port control as well as setting this bit.

#### **AADJE Bit (Automatic Adjustment Enable)**

This bit controls (enables or disables) automatic adjustment.

Set the plus-minus bits (RADJ.PMADJ[1:0]) to 00b (adjustment is not performed) before changing the value of the AADJE bit.

The AADJE bit is set to 0 by an RTC software reset.

#### **AADJP Bit (Automatic Adjustment Period Select)**

This bit selects the automatic-adjustment period.

Correction period can be selected from 32 second units or 8 second units in binary count mode.

Set the plus—minus bits (RADJ.PMADJ[1:0]) to 00b (adjustment is not performed) before changing the value of the AADJP bit.

The AADJP bit is set to 0 by an RTC software reset.

#### **CNTMD Bit (Count Mode Select)**

This bit specifies whether the RTC count mode is operated in calendar count mode or in binary count mode.

When setting the count mode, execute an RTC software reset and start again from the initial settings.

This bit is updated synchronously with the count source, and its value is fixed before the RTC software reset is completed.

For details on initial settings, refer to section 21.3.1, Outline of Initial Settings of Registers after Power On.



## 21.2.19 RTC Control Register 3 (RCR3)

Address(es): 0008 C426h



x: Undefined

| Bit      | Symbol     | Bit Name                                       | Description                                                                                                                                                                                              | R/W |
|----------|------------|------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | RTCEN      | Sub-Clock Oscillator Control                   | Sub-clock oscillator is stopped.     Sub-clock oscillator is operating.                                                                                                                                  | R/W |
| b3 to b1 | RTCDV[2:0] | Sub-Clock Oscillator Drive<br>Capacity Control | b3 b1 0 0 0: Medium drive capacity for low CL 0 0 1: High drive capacity for low CL 0 1 0: Low drive capacity for low CL 1 0 0: Drive capacity for standard CL Settings other than above are prohibited. | R/W |
| b7 to b4 | _          | Reserved                                       | These bits are read as 0. The write value should be 0.                                                                                                                                                   | R/W |

The RCR3 register is used for controlling the sub-clock oscillator in the clock generation circuit. For details on controlling the sub-clock oscillator, refer to section 9, Clock Generation Circuit.

This register is a function common to calendar count mode and binary count mode.

When this register is modified, check that all the bits have been updated before proceeding to the next processing.

#### **RTCEN Bit (Sub-Clock Oscillator Control)**

The RTCEN bit and a clock generation circuit register control whether to operate or stop the sub-clock oscillator. If one of the bits is set so as to enable the operation, the sub-clock oscillator runs.

When using the sub-clock as the count source to the RTC, set the sub-clock oscillator using the RTCEN bit.

### RTCDV[2:0] Bits (Sub-Clock Oscillator Drive Capacity Control)

These bits control the drive capacity of the sub-clock oscillator. Set the RTCDV[2:0] bits when the SOSCCR.SOSTP bit is 1 and the RCR3.RTCEN bit is 0.

#### (1) Notes on using a 32.768-kHz crystal

When the signal level of any pin near the XCIN or XCOUT pin is changed, the oscillation accuracy of the sub-clock oscillator may be affected. The accuracy is affected differently depending on the board traces and how the signal level of any pin near the XCIN or XCOUT pin is changed. When designing a board using a crystal, refer to the application note "Design Guide for Sub-clock Circuits" (R01AN1830EJ) to reduce the influence from noise.

## 21.2.20 Time Error Adjustment Register (RADJ)

Address(es): 0008 C42Eh



x: Undefined

| Bit      | Symbol     | Bit Name         | Description                                                                                                                                                                                                                                                | R/W |
|----------|------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b5 to b0 | ADJ[5:0]   | Adjustment Value | These bits specify the adjustment value from the prescaler.                                                                                                                                                                                                | R/W |
| b7, b6   | PMADJ[1:0] | Plus-Minus       | <ul> <li>b7 b6</li> <li>0 0: Adjustment is not performed.</li> <li>0 1: Adjustment is performed by the addition to the prescaler.</li> <li>1 0: Adjustment is performed by the subtraction from the prescaler.</li> <li>1 1: Setting prohibited</li> </ul> | R/W |

Adjustment is performed by the addition to or subtraction from the prescaler.

In case when the automatic adjustment enable (RCR2.AADJE) bit is 0, adjustment is performed when writing to the RADJ.

In case when the RCR2.AADJE bit is 1, adjustment is performed in the interval specified by the automatic adjustment period select (RCR2.AADJP) bit.

The current adjustment by software (disabling automatic adjustment) may be invalid if the following adjustment value is specified within 320 cycles of the count source after the register setting. To perform adjustment consecutively, wait for 320 cycles or more of the count source after the register setting and then specify the next adjustment value.

RADJ is updated in synchronization with the count source. When RADJ is modified, check that all the bits have been updated before continuing with further processing.

This register is set to 00h by an RTC software reset.

#### ADJ[5:0] Bits (Adjustment Value)

These bits specify the adjustment value (the number of sub-clock cycles) from the prescaler.

#### PMADJ[1:0] Bits (Plus-Minus)

These bits select whether the clock is set ahead or back depending on the error-adjustment value set in the ADJ[5:0] bits.



## 21.3 Operation

## 21.3.1 Outline of Initial Settings of Registers after Power On

After the power is turned on, the initial settings for the clock setting, count mode setting, time error adjustment, time setting, alarm, and interrupt should be performed.



Figure 21.2 Outline of Initial Settings after Power On

## 21.3.2 Clock and Count Mode Setting Procedure

Figure 21.3 shows how to set the clock and the count mode.



Figure 21.3 Clock and Count Mode Setting Procedure

## 21.3.3 Setting the Time

Figure 21.4 shows how to set the time.



Figure 21.4 Setting the Time

## 21.3.4 30-Second Adjustment

Figure 21.5 shows how to execute 30-second adjustment.



Figure 21.5 30-Second Adjustment

## 21.3.5 Reading 64-Hz Counter and Time

Figure 21.6 shows how to read the 64-Hz counter and time.



Figure 21.6 Reading Time

If a carry occurs while the 64-Hz counter and time are being read, the correct time will not be obtained, so they must be read again. The procedure for reading the time without using interrupts is shown in (a) in Figure 21.6, and the procedure using carry interrupts in (b). To keep the program simple, method (a) should be used in most cases.

#### 21.3.6 Alarm Function

Figure 21.7 shows how to use the alarm function.



Figure 21.7 Using Alarm Function

In calendar count mode, an alarm can be generated by any one of year, month, date, day-of-week, hour, minute or second, or any combination of those. Write 1 to the ENB bit in the alarm registers involved in the alarm setting, and set the alarm time in the lower bits. Write 0 to the ENB bit in registers not involved in the alarm setting.

In binary count mode, an alarm can be generated in any bit combination of 32 bits. Write 1 to the ENB bit of the alarm enable register corresponding to the target bit of the alarm, and set the alarm time to the alarm register. For bits that are not target of the alarm, write 0 to the ENB bit of the alarm enable register.

When the counter and the alarm time match, the IR flag corresponding to the ALM interrupt is set to 1. Alarm detection can be confirmed by reading this bit, but an interrupt should be used in most cases. If 1 has been set in the interrupt request enable bit corresponding to the ALM interrupt, an alarm interrupt is generated in the event of alarm, enabling the alarm to be detected.

Writing 0 sets the IR flag corresponding to the ALM interrupt to 0.

When the counter and the alarm time match in a low power consumption state, the MCU returns from the low power consumption state.

## 21.3.7 Procedure for Disabling Alarm Interrupt

Figure 21.8 shows the procedure for disabling the enabled alarm interrupt request.



Figure 21.8 Procedure for Disabling Alarm Interrupt Request

## 21.3.8 Time Error Adjustment Function

The time error adjustment function is used to correct errors (running fast or slow) in the time due to the precision of oscillation by the sub-clock. Since 32,768 cycles of the sub-clock constitute 1 second of operation when the sub-clock is selected, the clock runs fast if the sub-clock frequency is high and slow if the sub-clock frequency is low. This function can be used to correct errors due to the clock running fast or slow.

Two types of time error adjustment functions are provided: automatic adjustment and adjustment by software. Use the RCR2.AADJE bit to select automatic adjustment or adjustment by software.

### 21.3.8.1 Automatic Adjustment

Enable automatic adjustment by setting the RCR2.AADJE bit to 1.

Automatic adjustment is the addition or subtraction of the value counted by the prescaler to or from the value in the RADJ register every time the adjustment period selected by the RCR2.AADJE bit elapses. Examples are shown below.

[Example 1] Sub-clock running at 32.769 kHz

Adjustment procedure:

When the sub-clock is running at 32.769 kHz, 1 second elapses every 32,769 clock cycles. The RTC is meant to run at 32,768 clock cycles, so the clock runs fast by one clock cycle every second. The time on the clock is fast by 60 clock cycles per minute, so adjustment can take the form of setting the clock back by 60 cycles every minute.

Register settings: (when RCR2.CNTMD = 0)

- RCR2.AADJP = 0 (adjustment every minute)
- RADJ.PMADJ[1:0] = 10b (adjustment is performed by the subtraction from the prescaler.)
- RADJ.ADJ[5:0] = 60 (3Ch)

[Example 2] Sub-clock running at 32.766 kHz

Adjustment procedure:

When the sub-clock is running at 32.766 kHz, 1 second elapses every 32,766 clock cycles. The RTC is meant to run at 32,768 clock cycles, so the clock runs slow by two clock cycles every second. The time on the clock is slow by 20 clock cycles every 10 seconds, so adjustment can take the form of setting the clock forward by 20 cycles every 10 seconds.

Register settings: (when RCR2.CNTMD = 0)

- RCR2.AADJP = 1 (adjustment every 10 seconds)
- RADJ.PMADJ[1:0] = 01b (adjustment is performed by the addition to the prescaler.)
- RADJ.ADJ[5:0] = 20 (14h)

[Example 3] Sub-clock running at 32.764 kHz

Adjustment procedure:

At 32.764 kHz, 1 second elapses on 32,764 clock cycles. Since the RTC operates for 32,768 clock cycles as 1 second, the clock is delayed for four clock cycles per second. In 8 seconds, the delay is 32 clock cycles, so correction can be made by proceeding the clock for 32 clock cycles every 8 seconds.

Register settings when the RCR2.CNTMD bit is 1

- RCR2.AADJP = 1 (adjustment every 8 seconds)
- RADJ.PMADJ[1:0] = 01b (adjustment is performed by the addition to the prescaler.)
- RADJ.ADJ[5:0] = 32 (20h)

## 21.3.8.2 Adjustment by Software

Enable adjustment by software by setting the RCR2.AADJE bit to 0.

Adjustment by software is the addition or subtraction of the value counted by the prescaler to or from the value in the RADJ register at the time of execution of an instruction for writing to the RADJ register.

An example is shown below.

[Example 1] Sub-clock running at 32.769 kHz

Adjustment procedure:

When the sub-clock is running at 32.769 kHz, 1 second elapses every 32,769 clock cycles. The RTC is meant to run at 32,768 clock cycles, so the clock runs fast by one clock cycle every second. The time on the clock is fast by one clock cycle per second, so adjustment can take the form of setting the clock back by one cycle every second.

## Register settings:

- RADJ.PMADJ[1:0] = 10b (adjustment is performed by the subtraction from the prescaler.)
- RADJ.ADJ[5:0] = 1 (01h)

This is written to the RADJ register once per 1-second interrupt.



## 21.3.8.3 Procedure for Changing the Mode of Adjustment

When changing the mode of adjustment, change the value of the AADJE bit in RCR2 after setting the RADJ.PMADJ[1:0] bits to 00b (adjustment is not performed).

Changing from adjustment by software to automatic adjustment:

- (1) Set the RADJ.PMADJ[1:0] bits to 00b (adjustment is not performed).
- (2) Set the RCR2.AADJE bit to 1 (automatic adjustment is enabled).
- (3) Use the RCR2.AADJP bit to select the period of adjustment.
- (4) In RADJ, set the PMADJ[1:0] bits for addition or subtraction and the ADJ[5:0] bits to the value for use in time error adjustment.

Changing from adjustment by software to automatic adjustment:

- (1) Set the RADJ.PMADJ[1:0] bits to 00b (adjustment is not performed).
- (2) Set the RCR2.AADJE bit to 0 (adjustment by software is enabled).
- (3) Proceed with adjustment by setting the RADJ.PMADJ[1:0] bits for addition or subtraction and the RADJ.ADJ[5:0] bits to the value for use in time error adjustment at the desired time. After that, the time is adjusted every time a value is written to the RADJ register.

### 21.3.8.4 Procedure for Stopping Adjustment

Stop adjustment by setting the RADJ.PMADJ[1:0] bits to 00b (adjustment is not performed).

#### 21.4 Interrupt Sources

There are three interrupt sources in the realtime clock. Table 21.3 lists interrupt sources for the RTC.

Table 21.3 RTC Interrupt Sources

| Name | Interrupt Sources  |
|------|--------------------|
| ALM  | Alarm interrupt    |
| PRD  | Periodic interrupt |
| CUP  | Carry interrupt    |

#### (1) Alarm interrupt (ALM)

This interrupt is generated according to the result of comparison between the alarm registers and realtime clock counters (for details, refer to section 21.3.6, Alarm Function).

Since there is a possibility that the interrupt flag may be set to 1 when the settings of the alarm registers match the clock counters, wait for the alarm time settings to be confirmed and set the IR flag corresponding to the ALM interrupt to 0 again after modifying values of the alarm registers. Once the interrupt flag for the alarm interrupt has been set to 1 and the state has returned to non-matching of the alarm registers and clock counters, the flag will not be set again until there is a further match or the values of the alarm registers are modified again.



Figure 21.9 Timing Chart for the Alarm Interrupt (ALM)

#### (2) Periodic interrupt (PRD)

This interrupt is generated at intervals of 2 seconds, 1 second, 1/2 second, 1/4 second, 1/8 second, 1/16 second, 1/32 second, 1/64 second, 1/128 second, or 1/256 second. The interrupt interval can be selected through the RCR1.PES[3:0] bits.

#### (3) Carry interrupt (CUP)

This interrupt is generated when a carry to the second counter/binary counter 0 occurred or a carry to the R64CNT counter occurred during read access to the 64-Hz counter.



Figure 21.10 Carry Interrupt (CUP) Timing Chart

## 21.5 Usage Notes

## 21.5.1 Register Writing during Counting

The following registers should not be written to during counting (while the RCR2.START bit = 1).

RSECCNT/BCNT0, RMINCNT/BCNT1, RHRCNT/BCNT2, RDAYCNT, RWKCNT/BCNT3, RMONCNT, RYRCNT, RCR1.RTCOS, RCR2.RTCOE, RCR2.HR24

The counter must be stopped before writing to any of the above registers.

#### 21.5.2 Use of Periodic Interrupts

The procedure for using periodic interrupts is shown in Figure 21.11.

The generation and period of the periodic interrupt can be changed by the setting of the RCR1.PES[3:0] bits. However, since the prescaler, R64CNT, and RSECCNT/BCNT0 are used to generate interrupts, the interrupt period is not guaranteed immediately after setting of the RCR1.PES[3:0] bits.

Furthermore, stopping/restarting or resetting counter operation, reset by RTC software, and the 30-second adjustment by changing the RCR2 value affects the interrupt period. When the time error adjustment function is used, the interrupt generation period after adjustment is added or subtracted according to the adjustment value.



Figure 21.11 Using Periodic Interrupt Function

#### 21.5.3 RTCOUT (1-Hz/64-Hz) Clock Output

Stopping/restarting or resetting counter operation, reset by RTC software, and the 30-second adjustment by changing the RCR2 value affects the period of RTCOUT (1-Hz/64-Hz) output. When the time error adjustment function is used, the period of RTCOUT (1-Hz/64-Hz) output after adjustment is added or subtracted according to the adjustment value.

## 21.5.4 Transitions to Low Power Consumption Modes after Setting Registers

A transition to a low power consumption state (software standby mode) during writing to or updating of an RTC register might destroy the register's value. After setting a register, confirm that the setting is in place before initiating a transition to a low power consumption state.

## 21.5.5 Notes When Writing to and Reading from Registers

- When reading a counter register such as the second counter/binary counter after having written to the counter register, follow the procedure in section 21.3.5, Reading 64-Hz Counter and Time.
- The value written to the count registers, alarm registers, year alarm enable register, bits RCR2.AADJE, AADJP, and HR24, or RCR3 register is reflected when four read operations are performed after writing.
- The values written to the RCR1.CIE, RTCOS, and RCR2.RTCOE bits can be read immediately after writing.
- To read the value from the timer counter after return from a reset or software standby mode, wait for 1/128 second while the clock is operating (RCR2.START bit = 1).
- · After a reset is generated, write to the RTC register when six cycles of the count source clock have elapsed.

## 21.5.6 Changing the Count Mode

When changing the count mode (calendar/binary), set the RCR2.START bit to 0, stop counting operation, then start again from the initial setting. For details on initial setting, refer to section 21.3.1, Outline of Initial Settings of Registers after Power On.

#### 21.5.7 Initialization Procedure When the Realtime Clock is Not to be Used

Registers in the RTC are not initialized by a reset. Accordingly, depending on the initial state, the generation of an unintentional interrupt request or operation of the counter may lead to increased power consumption.

For products that do not require a realtime clock, initialize the registers by following the initialization procedure shown in Figure 21.12.



Figure 21.12 Initialization Procedure

## 22. Independent Watchdog Timer (IWDTa)

In this section, "PCLK" is used to refer to PCLKB.

#### 22.1 Overview

The independent watchdog timer (IWDT) can be used to detect programs being out of control.

The user can detect when a program runs out of control if an underflow occurs, by creating a program that refreshes the IWDT counter before it underflows.

The functions of the IWDT are different from those of the WDT in the following respects.

- The divided IWDT-dedicated low-speed clock (IWDTCLK) is used as the count source (not affected by the PCLK).
- When making a transition to sleep mode, software standby mode, or deep sleep mode, the IWDTCSTPR.SLCSTP bit or the OFS0.IWDTSLCSTP bit can be used to select whether to stop the counter or not.

Table 22.1 lists the specifications of the IWDT and Figure 22.1 shows a block diagram of the IWDT.

Table 22.1 IWDT Specifications

| Item                                                                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Count source*1                                                                 | IWDT-dedicated clock (IWDTCLK)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Clock divide ratio                                                             | Divide by 1, 16, 32, 64, 128, or 256                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Counter operation                                                              | Counting down using a 14-bit down-counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Conditions for starting the counter                                            | <ul> <li>Counting automatically starts after a reset (auto-start mode)</li> <li>Counting is started (register start mode) by refreshing the counter (writing 00h and then FFh to the IWDTRR register).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Conditions for stopping the counter                                            | <ul> <li>Reset (the down-counter and other registers return to their initial values)</li> <li>A counter underflows or a refresh error occurs Counting restarts (In auto-start mode, counting automatically restarts after a reset or after a non-maskable interrupt request is output. In register start mode, counting restarts after refreshing.)</li> </ul>                                                                                                                                                                                                                                                                                              |
| Window function                                                                | Window start and end positions can be specified (refresh-permitted and refresh-prohibited periods)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Reset output sources                                                           | Down-counter underflows     Refreshing outside the refresh-permitted period (refresh error)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Non-maskable interrupt sources                                                 | Down-counter underflows     Refreshing outside the refresh-permitted period (refresh error)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Reading the counter value                                                      | The down-counter value can be read by the IWDTSR register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Output signal (internal signal)                                                | Reset output     Interrupt request output     Sleep mode count stop control output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Auto-start mode<br>(controlled by option function<br>select register 0 (OFS0)) | <ul> <li>Selecting the clock frequency divide ratio after a reset (OFS0.IWDTCKS[3:0] bits)</li> <li>Selecting the timeout period of the independent watchdog timer (OFS0.IWDTTOPS[1:0] bits)</li> <li>Selecting the window start position in the independent watchdog timer (OFS0.IWDTRPSS[1:0] bits)</li> <li>Selecting the window end position in the independent watchdog timer (OFS0.IWDTRPES[1:0] bits)</li> <li>Selecting the reset output or interrupt request output (OFS0.IWDTRSTIRQS bit)</li> <li>Selecting the down-count stop function at transition to sleep mode, software standby mode, or deep sleep mode (OFS0.IWDTSLCSTP bit)</li> </ul> |
| Register start mode<br>(controlled by the IWDT<br>registers)                   | <ul> <li>Selecting the clock frequency divide ratio after refreshing (IWDTCR.CKS[3:0] bits)</li> <li>Selecting the timeout period of the independent watchdog timer (IWDTCR.TOPS[1:0] bits)</li> <li>Selecting the window start position in the independent watchdog timer (IWDTCR.RPSS[1:0] bits)</li> <li>Selecting the window end position in the independent watchdog timer (IWDTCR.RPES[1:0] bits)</li> <li>Selecting the reset output or interrupt request output (IWDTRCR.RSTIRQS bit)</li> <li>Selecting the down-count stop function at transition to sleep mode, software standby mode, or deep sleep mode (IWDTCSTPR.SLCSTP bit)</li> </ul>      |

Note 1. Satisfy the frequency of the peripheral module clock (PCLK)  $\geq$  4 x (the frequency of the count source after divide).

To use the IWDT, the IWDT-dedicated clock (IWDTCLK) should be supplied so that the IWDT operates even if the peripheral module clock (PCLK) stops. The bus interface and registers operate with PCLK, and the 14-bit counter and control circuits operate with IWDTCLK.

Figure 22.1 is a block diagram of the IWDT.



Figure 22.1 IWDT Block Diagram

## 22.2 Register Descriptions

## 22.2.1 IWDT Refresh Register (IWDTRR)

Address(es): IWDT.IWDTRR 0008 8030h



| Bit      | Description                                                                    | R/W |
|----------|--------------------------------------------------------------------------------|-----|
| b7 to b0 | The counter is refreshed by writing 00h and then writing FFh to this register. | R/W |

The IWDTRR register refreshes the counter of the IWDT.

The counter of the IWDT is refreshed by writing 00h and then writing FFh to the IWDTRR register (refresh operation) within the refresh-permitted period.

After the counter has been refreshed, it starts counting down from the value selected by the IWDT timeout period select bits (OFS0.IWDTTOPS[1:0]) in option function select register 0 (OFS0) in auto-start mode. In register start mode, counting down starts from the value selected by setting the timeout period select bits (TOPS[1:0]) in the IWDT control register (IWDTCR) in the first refresh operation after release from the reset state.

When 00h is written, the read value is 00h. When a value other than 00h is written, the read value is FFh. For details of the refresh operation, refer to section 22.3.3, Refresh Operation.

# 22.2.2 IWDT Control Register (IWDTCR)

Address(es): IWDT.IWDTCR 0008 8032h



| Bit      | Symbol    | Bit Name                                                                                                     | Description                                                                                                                                                               | R/W |
|----------|-----------|--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1, b0   | TOPS[1:0] | Timeout Period Select                                                                                        | b1 b0<br>0 0: 128 cycles (007Fh)<br>0 1: 512 cycles (01FFh)<br>1 0: 1024 cycles (03FFh)<br>1 1: 2048 cycles (07FFh)                                                       | R/W |
| b3, b2   | _         | Reserved                                                                                                     | These bits are read as 0. Writing to these bits has no effect.                                                                                                            | R   |
| b7 to b4 | CKS[3:0]  | Clock Divide Ratio Select                                                                                    | b7 b4 0 0 0 0: No division 0 0 1 0: Divide-by-16 0 0 1 1: Divide-by-32 0 1 0 0: Divide-by-64 1 1 1 1: Divide-by-128 0 1 0 1: Divide-by-256 Other settings are prohibited. | R/W |
| b9, b8   | RPES[1:0] | Window End Position Select  b9 b8 0 0: 75% 0 1: 50% 1 0: 25% 1 1: 0% (window end position is not specified.) |                                                                                                                                                                           | R/W |
| b11, b10 | _         | Reserved                                                                                                     | These bits are read as 0. Writing to these bits has no effect.                                                                                                            | R   |
| b13, b12 | RPSS[1:0] | Window Start Position Select                                                                                 | b13 b12<br>0 0: 25%<br>0 1: 50%<br>1 0: 75%<br>1 1: 100% (window start position is not specified.)                                                                        | R/W |
| b15, b14 | _         | Reserved                                                                                                     | These bits are read as 0. Writing to these bits has no effect.                                                                                                            | R   |

There are some restrictions on writing to the IWDTCR register. For details, refer to section 22.3.2, Control over Writing to the IWDTCR, IWDTRCR, and IWDTCSTPR Registers.

In auto-start mode, the settings in the IWDTCR register are disabled, and the settings in option function select register 0 (OFS0) are enabled. The bit setting made to the IWDTCR register can also be made in option function select register 0 (OFS0). For details, refer to section 22.3.8, Correspondence between Option Function Select Register 0 (OFS0) and IWDT Registers.

#### TOPS[1:0] Bits (Timeout Period Select)

These bits select the timeout period (period until the counter underflows) from among 128, 512, 1024, or 2048 cycles, taking the divided clock specified by the CKS[3:0] bits as one cycle.

After the counter is refreshed, the combination of the CKS[3:0] and TOPS[1:0] bits determines the time (number of IWDTCLK cycles) until the counter underflows.

Relations between the CKS[3:0] and TOPS[1:0] bit setting, the timeout period, and the number of IWDTCLK cycles are listed in Table 22.2.

Table 22.2 Settings and Timeout Periods

|    | CKS[3 | :0] Bits |    | TOPS[1 | :0] Bits |                    | Timeout Period     |                   |
|----|-------|----------|----|--------|----------|--------------------|--------------------|-------------------|
| b7 | b6    | b5       | b4 | b1     | b0       | Clock Divide Ratio | (Number of Cycles) | Cycles of IWDTCLK |
| 0  | 0     | 0        | 0  | 0      | 0        | No division        | 128                | 128               |
|    |       |          | _  | 0      | 1        | <del>_</del>       | 512                | 512               |
|    |       |          | _  | 1      | 0        | <del>_</del>       | 1024               | 1024              |
|    |       |          | _  | 1      | 1        | <del>_</del>       | 2048               | 2048              |
| 0  | 0     | 1        | 0  | 0      | 0        | Divide-by-16       | 128                | 2048              |
|    |       |          | _  | 0      | 1        | <del>_</del>       | 512                | 8192              |
|    |       |          | _  | 1      | 0        | <del>_</del>       | 1024               | 16384             |
|    |       |          | _  | 1      | 1        | <del>_</del>       | 2048               | 32768             |
| 0  | 0     | 1        | 1  | 0      | 0        | Divide-by-32       | 128                | 4096              |
|    |       |          | _  | 0      | 1        | <del>_</del>       | 512                | 16384             |
|    |       |          | _  | 1      | 0        | <del>_</del>       | 1024               | 32768             |
|    |       |          | _  | 1      | 1        | <del>_</del>       | 2048               | 65536             |
| 0  | 1     | 0        | 0  | 0      | 0        | Divide-by-64       | 128                | 8192              |
|    |       |          | _  | 0      | 1        | <del>_</del>       | 512                | 32768             |
|    |       |          | _  | 1      | 0        | <del>_</del>       | 1024               | 65536             |
|    |       |          | _  | 1      | 1        | <del>_</del>       | 2048               | 131072            |
| 1  | 1     | 1        | 1  | 0      | 0        | Divide-by-128      | 128                | 16384             |
|    |       |          | _  | 0      | 1        | <del>_</del>       | 512                | 65536             |
|    |       |          | _  | 1      | 0        | <del>_</del>       | 1024               | 131072            |
|    |       |          | _  | 1      | 1        | <del>_</del>       | 2048               | 262144            |
| 0  | 1     | 0        | 1  | 0      | 0        | Divide-by-256      | 128                | 32768             |
|    |       |          | _  | 0      | 1        | _                  | 512                | 131072            |
|    |       |          | _  | 1      | 0        | _                  | 1024               | 262144            |
|    |       |          | _  | 1      | 1        | _                  | 2048               | 524288            |

## CKS[3:0] Bits (Clock Divide Ratio Select)

These bits select the IWDTCLK clock divide ratio from among divide-by 1, 16, 32, 64, 128, and 256. Combination with the TOPS[1:0] bit setting, a count period between 128 and 524288 cycles of the IWDTCLK clock can be selected for the IWDT.

### RPES[1:0] Bits (Window End Position Select)

These bits select 75%, 50%, 25% or 0% of the count period for the window end position of the counter. The window end position should be a value smaller than the window start position (window start position > window end position). If the window end position is greater than the window start position, only the window start position setting is enabled.

The counter values for the window start and end positions selected by setting the RPSS[1:0] and RPES[1:0] bits change depending on the TOPS[1:0] bit setting.

Table 22.3 lists the counter values for the window start and end positions corresponding to TOPS[1:0] bit values.

Table 22.3 Relationship between Timeout Period and Window Start and End Counter Values

TOPS(1:0) Rits | Timeout Period | Window Start and End Counter Value

| TOPS[1 | TOPS[1:0] Bits Timeout Period |        | TOPS[1:0] Bits Timeout Period Window Start and End Counter Value |       |       | е     |       |
|--------|-------------------------------|--------|------------------------------------------------------------------|-------|-------|-------|-------|
| b1     | b0                            | Cycles | Counter Value                                                    | 100%  | 75%   | 50%   | 25%   |
| 0      | 0                             | 128    | 007Fh                                                            | 007Fh | 005Fh | 003Fh | 001Fh |
| 0      | 1                             | 512    | 01FFh                                                            | 01FFh | 017Fh | 00FFh | 007Fh |
| 1      | 0                             | 1024   | 03FFh                                                            | 03FFh | 02FFh | 01FFh | 00FFh |
| 1      | 1                             | 2048   | 07FFh                                                            | 07FFh | 05FFh | 03FFh | 01FFh |

### RPSS[1:0] Bits (Window Start Position Select)

These bits select a counter window start position from 100%, 75%, 50%, or 25% of the count period (100% when the count starts and 0% when the counter underflows). The interval between the window start position and window end position is the refresh-permitted period and the other periods are refresh-prohibited periods.

Figure 22.2 shows the relationship between of the RPSS[1:0] and RPES[1:0] bit setting and the refresh-permitted and refresh-prohibited periods.



Figure 22.2 RPSS[1:0] and RPES[1:0] Bit Settings and the Refresh-Permitted Period

# 22.2.3 IWDT Status Register (IWDTSR)

Address(es): IWDT.IWDTSR 0008 8034h



| Bit       | Symbol       | Bit Name           | Description                                            | R/W         |
|-----------|--------------|--------------------|--------------------------------------------------------|-------------|
| b13 to b0 | CNTVAL[13:0] | Counter Value      | Value counted by the counter                           | R           |
| b14       | UNDFF        | Underflow Flag     | 0: No underflow occurred 1: Underflow occurred         | R/(W)<br>*1 |
| b15       | REFEF        | Refresh Error Flag | 0: No refresh error occurred 1: Refresh error occurred | R/(W)<br>*1 |

Note 1. Only 0 can be written to clear the flag.

The IWDTSR register is initialized by the reset source of the IWDT. The IWDTSR register is not initialized by other reset sources.

#### CNTVAL[13:0] Bits (Counter Value)

These bits are used to confirm the counter value of the counter, but note that the read value may differ from the actual count by a value of one count.

## **UNDFF Flag (Underflow Flag)**

This bit is used to confirm whether or not an underflow has occurred in the counter.

The value 1 indicates that the counter has underflowed. The value 0 indicates that the counter has not underflowed. Write 0 to the UNDFF flag to set the value to 0. Writing 1 has no effect.

# REFEF Flag (Refresh Error Flag)

This bit is used to confirm whether or not a refresh error (performing a refresh operation during a refresh-prohibited period).

The value 1 indicates that a refresh error has occurred. The value 0 indicates that no refresh error has occurred. Write 0 to the REFEF flag to set the value to 0. Writing 1 has no effect.

# 22.2.4 IWDT Reset Control Register (IWDTRCR)

Address(es): IWDT.IWDTRCR 0008 8036h



| Bit      | Symbol  | Bit Name Description           |                                                                                | R/W |
|----------|---------|--------------------------------|--------------------------------------------------------------------------------|-----|
| b6 to b0 | _       | Reserved                       | These bits are read as 0. Writing to these bits has no effect.                 | R   |
| b7       | RSTIRQS | Reset Interrupt Request Select | Non-maskable interrupt request output is enabled.     Reset output is enabled. | R/W |

There are some restrictions on writing to the IWDTRCR register. For details, refer to section 22.3.2, Control over Writing to the IWDTCR, IWDTRCR, and IWDTCSTPR Registers.

In auto-start mode, the IWDTRCR register setting are disabled, and the settings in option function select register 0 (OFS0) are enabled. The bit setting mode to the IWDTRCR register can also be made in option function select register 0. For details, refer to section 22.3.8, Correspondence between Option Function Select Register 0 (OFS0) and IWDT Registers.

# 22.2.5 IWDT Count Stop Control Register (IWDTCSTPR)

Address(es): IWDT.IWDTCSTPR 0008 8038h



| Bit      | Symbol | Bit Name                      | Description                                                                                                                                        | R/W |
|----------|--------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b6 to b0 | _      | Reserved                      | These bits are read as 0. Writing to these bits has no effect.                                                                                     | R   |
| b7       | SLCSTP | Sleep Mode Count Stop Control | <ul><li>0: Count stop is disabled.</li><li>1: Count is stopped at a transition to sleep mode, software standby mode, or deep sleep mode.</li></ul> | R/W |

The IWDTCSTPR register controls whether to stop the IWDT counter in a low power consumption state. There are some restrictions on writing to the IWDTCSTPR register. For details, refer to section 22.3.2, Control over Writing to the IWDTCR, IWDTRCR, and IWDTCSTPR Registers.

In auto-start mode, the IWDTCSTPR register setting are disabled, and the settings in option function select register 0 (OFS0) are enabled. The bit setting mode to the IWDTCSTPR register can also be made in option function select register 0 (OFS0). For details, refer to section 22.3.8, Correspondence between Option Function Select Register 0 (OFS0) and IWDT Registers.

## **SLCSTP Bit (Sleep Mode Count Stop Control)**

This bit selects whether to stop counting at a transition to sleep mode, software standby mode, or deep sleep mode.

# 22.2.6 Option Function Select Register 0 (OFS0)

For option function select register 0 (OFS0), refer to section 22.3.8, Correspondence between Option Function Select Register 0 (OFS0) and IWDT Registers.

# 22.3 Operation

## 22.3.1 Count Operation in Each Start Mode

Select the IWDT start mode by setting the IWDT start mode select bit (OFS0.IWDTSTRT) in option function select register 0.

When the OFS0.IWDTSTRT bit is 1 (register start mode), the IWDT control register (IWDTCR), IWDT reset control register (IWDTRCR), and IWDT count stop control register (IWDTCSTPR) are enabled, and counting is started by refreshing (writing) the IWDT refresh register (IWDTRR). When the OFS0.IWDTSTRT bit is 0 (auto-start mode), the setting of option function select register 0 (OFS0) is enabled, and counting automatically starts after reset.

## 22.3.1.1 Register Start Mode

When the IWDT start mode select bit (OFS0.IWDTSTRT) in option function select register 0 is 1, register start mode is selected, and the IWDT control register (IWDTCR), IWDT reset control register (IWDTRCR), and IWDT count stop control register (IWDTCSTPR) are enabled.

After the reset state is released, set the clock divide ratio, window start and end positions, and timeout period in the IWDTCR register, the reset output or interrupt request output in the IWDTRCR register, and the counter stop control at transitions to low power consumption states in the IWDTCSTPR register. Then refresh the counter to start counting down from the value selected by setting the timeout period select bits (IWDTCR.TOPS[1:0]).

Thereafter, as long as the program continues normal operation and the counter is refreshed in the refresh-permitted period, the value in the counter is re-set each time the counter is refreshed and counting down continues. The IWDT does not output the reset signal as long as this continues. However, if the counter underflows because the counter cannot be refreshed due to a program runaway, or if a refresh error occurs because the counter was refreshed outside the refresh-permitted period, the IWDT outputs a reset signal or a non-maskable interrupt request (WUNI). Set the IWDT reset interrupt request select bit (IWDTRCR.RSTIRQS) to select either reset output or interrupt request output.

Figure 22.3 shows an example of operation under the following conditions.

- The IWDT start mode select bit (OFS0.IWDTSTRT) is 1 (register start mode)
- The IWDT reset interrupt request select bit (IWDTRCR.RSTIRQS) is 1 (reset output is enabled)
- The IWDT window start position select bits (IWDTCR.RPSS[1:0]) are 10b (75%)
- The IWDT window end position select bits (IWDTCR.RPES[1:0]) are 10b (25%)



Figure 22.3 Operation Example in Register Start Mode

#### 22.3.1.2 Auto-Start Mode

When the IWDT start mode select bit (OFS0.IWDTSTRT) in option function select register 0 is 0, auto-start mode is selected, and the IWDT control register (IWDTCR), IWDT reset control register (IWDTRCR), and IWDT count stop control register (IWDTCSTPR) are disabled.

Within the reset state, the clock divide ratio, window start and end positions, timeout period, reset output or interrupt request output, and counter stop control at transitions to low power consumption states are set using the values specified in option function select register 0 (OFS0). When the reset state is released, the counter automatically starts counting down from the value selected by the IWDT timeout period select bits (OFS0.IWDTTOPS[1:0]).

After that, as long as the program continues normal operation and the counter is refreshed in the refresh-permitted period, the value in the counter is re-set each time the counter is refreshed and counting down continues. The IWDT does not output the reset signal as long as this continues. However, if the counter underflows because refreshing of the counter is not possible due to the program having entered crashed execution or if a refresh error occurs due to refreshing outside the refresh-permitted period, the IWDT outputs the reset signal or non-maskable interrupt request (WUNI). After the reset signal or non-maskable interrupt request (WUNI) is generated, the counter reloads the timeout period after counting for one cycle, and restarts counting. Set the IWDT reset interrupt request select bit (OFS0.IWDTRSTIRQS) to select either reset output or interrupt request output.

Figure 22.4 shows an example of operation under the following conditions.

- The IWDT start mode select bit (OFS0.IWDTSTRT) is 0 (auto-start mode)
- The IWDT reset interrupt request select bit (OFS0.IWDTRSTIRQS) is 0 (non-maskable interrupt request output is enabled)
- The IWDT window start position select bits (OFS0.IWDTRPSS[1:0]) are 10b (75%)
- The IWDT window end position select bits (OFS0.IWDTRPES[1:0]) are 10b (25%)



Figure 22.4 Operation Example in Auto-Start Mode

# 22.3.2 Control over Writing to the IWDTCR, IWDTRCR, and IWDTCSTPR Registers

Writing to the IWDT control register (IWDTCR), IWDT reset control register (IWDTRCR), or IWDT count stop control register (IWDTCSTPR) is only possible once between the release from the reset state and the first refresh operation. After a refresh operation (counting starts) or the IWDTCR, IWDTRCR, or IWDTCSTPR register is written to, the protection signal in the IWDT becomes 1 to protect registers IWDTCR, IWDTRCR, and IWDTCSTPR against subsequent attempts at writing.

This protection is released by the reset source of the IWDT. With other reset sources, the protection is not released. Figure 22.5 shows control waveforms produced in response to writing to the IWDTCR register.



Figure 22.5 Control Waveforms Produced in Response to Writing to the IWDTCR Register

## 22.3.3 Refresh Operation

The counter is refreshed and starts operation (counting is started by refreshing) by writing the values 00h and then FFh to the IWDT refresh register (IWDTRR). If a value other than FFh is written after 00h, the counter is not refreshed. After such invalid writing, correct refreshing is performed by again writing 00h and then FFh to the IWDT refresh register (IWDTRR).

When writing is done in the order of 00h (first time)  $\rightarrow$  00h (second time), and if FFh is written after that, the writing order  $00h \rightarrow FFh$  is satisfied; writing  $00h (n-1-th time) \rightarrow 00h$  (nth time)  $\rightarrow FFh$  is valid and correct refreshing will be done. Even when the first value written before 00h is not 00h, correct refreshing will be done if the operation contains the set of writing  $00h \rightarrow FFh$ . Moreover, even if a register other than the IWDTRR register is accessed or the IWDTRR register is read between writing 00h and writing FFh to the IWDTRR register, correct refreshing will be done.

[Sample sequences of writing that are valid for refreshing the counter]

- $00h \rightarrow FFh$
- $00h (n-1-th time) \rightarrow 00h (nth time) \rightarrow FFh$
- 00h → access to another register or read from the IWDTRR register → FFh

[Sample sequences of writing that are not valid for refreshing the counter]

- 23h (a value other than 00h)  $\rightarrow$  FFh
- $00h \rightarrow 54h$  (a value other than FFh)
- $00h \rightarrow AAh (00h \text{ and a value other than } FFh) \rightarrow FFh$

Even when 00h is written to the IWDTRR register outside the refresh-permitted period, if FFh is written to the IWDTRR register in the refresh-permitted period, the writing sequence is valid and refreshing will be done.

After FFh is written to the IWDTRR register, refreshing the counter requires up to four cycles of the signal for counting (the clock divide ratio selection bits (IWDTCR.CKS[3:0]) determine how many cycles of the IWDT-dedicated clock (IWDTCLK) make up one cycle for counting). Therefore, writing FFh to the IWDTRR register should be completed four-count cycles before the end position of the refresh-permitted period or a counter underflow. The value of the counter can be checked by the counter bits (IWDTSR.CNTVAL[13:0]).

#### [Sample refreshing timings]

- When the window start position is set to 03FFh, even if 00h is written to the IWDTRR register before 03FFh is reached (0402h, for example), refreshing is done if FFh is written to the IWDTRR register after the value of the IWDTSR.CNTVAL[13:0] bits has reached 03FFh.
- When the window end position is set to 03FFh, refreshing is done if 0403h (four-count cycles before 03FFh) or a
  greater value is read from the IWDTSR.CNTVAL[13:0] bits immediately after writing 00h → FFh to the IWDTRR
  register.
- When the refresh-permitted period continues until count 0000h, refreshing can be done immediately before an
  underflow. In this case, if 0003h (four-count cycles before an underflow) or a greater value is read from the
  IWDTSR.CNTVAL[13:0] bits immediately after writing 00h → FFh to the IWDTRR register, no underflow occurs
  and refreshing is done.

Figure 22.6 shows the IWDT refresh-operation waveforms when PCLK > IWDTCLK and clock divide ratio = IWDTCLK.



Figure 22.6 IWDT Refresh Operation Waveforms (IWDTCR.CKS[3:0] = 0000b, IWDTCR.TOPS[1:0] = 11b)

# 22.3.4 Status Flags

The refresh error (IWDTSR.REFEF) and underflow (IWDTSR.UNDFF) flags retain the source of the reset signal output from the IWDT or the source of the interrupt request from the IWDT.

Thus, after release from the reset state or interrupt request generation, read the IWDTSR.REFEF and IWDTSR.UNDFF flags to check for the reset or interrupt source.

For each flag, writing 0 clears the bit and writing 1 has no effect.

Leaving the status flags unchanged does not affect operation. If the flags are not cleared, at the time of the next reset or interrupt request from the IWDT, the earlier reset or interrupt source is cleared and the new reset or interrupt source is written.

After 0 is written to each flag, up to three IWDTCLK cycles and two PCLK cycles are required before the value is reflected.

## 22.3.5 Reset Output

When the reset interrupt selection bit (IWDTRCR.RSTIRQS) is set to 1 in register start mode or when the IWDT reset interrupt request select bit (OFS0.IWDTRSTIRQS) in option function select register 0 (OFS0) is set to 1 in auto-start mode, a reset signal is output when an underflow in the counter or a refresh error occurs.

In register start mode, the counter is initialized (all bits set to 0) and kept in that state after assertion of the reset signal. After the reset is released and the program is restarted, the counter is set up again and counting down is started by refreshing.

In auto-start mode, counting down automatically starts after the reset output.

## 22.3.6 Interrupt Sources

When the reset interrupt selection bit (IWDTRCR.RSTIRQS) is set to 0 in register start mode or when the IWDT reset interrupt request select bit (OFS0.IWDTRSTIRQS) in option function select register 0 (OFS0) is set to 0 in auto-start mode, an interrupt (WUNI) signal is output when an underflow in the counter or a refresh error occurs. This interrupt can be used as a non-maskable interrupt. For details, refer to section 14, Interrupt Controller (ICUb).

Table 22.4 IWDT Interrupt Source

| Name | Interrupt Source                   | DTC Activation |
|------|------------------------------------|----------------|
| WUNI | Counter underflow<br>Refresh error | Not possible   |

# 22.3.7 Reading the Counter Value

As the counter in IWDT-dedicated clock (IWDTCLK), the counter value cannot be read directly. The IWDT synchronizes the counter value with the peripheral module clock (PCLK) and stores it in the counter value bits (IWDTSR.CNTVAL[13:0]) of the IWDT status register. Thus, the counter value can be checked indirectly through the IWDTSR.CNTVAL[13:0] bits.

Reading the counter value requires multiple PCLK clock cycles (up to four clock cycles), and the read counter value may differ from the actual counter value by a value of one count.

Figure 22.7 shows the processing for reading the IWDT counter value when PCLK > IWDTCLK and clock divide ratio = IWDTCLK.



Figure 22.7 Processing for Reading IWDT Counter Value (IWDTCR.CKS[3:0] = 0000b, IWDTCR.TOPS[1:0] = 11b)

# 22.3.8 Correspondence between Option Function Select Register 0 (OFS0) and IWDT Registers

Table 22.5 lists the correspondence between option function select register 0 (OFS0) used in auto-start mode and the registers used in register start mode.

Do not change the OFS0 register setting during IWDT operation.

For details on option function select register 0 (OFS0), refer to section 7.2.1, Option Function Select Register 0 (OFS0).

Table 22.5 Correspondence between Option Function Select Register 0 (OFS0) and IWDT Registers

| Target of Control                        | Function                                           | OFS0 Register<br>(Enabled in Auto-Start Mode)<br>OFS0.IWDTSTRT = 0 | IWDT Registers<br>(Enabled in Register Start Mode)<br>OFS0.IWDTSTRT = 1 |
|------------------------------------------|----------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------|
| Counter                                  | Timeout period selection                           | OFS0.IWDTTOPS[1:0]                                                 | IWDTCR.TOPS[1:0]                                                        |
|                                          | Clock frequency divide ratio selection             | OFS0.IWDTCKS[3:0]                                                  | IWDTCR.CKS[3:0]                                                         |
|                                          | Window start position selection                    | OFS0.IWDTRPSS[1:0]                                                 | IWDTCR.RPSS[1:0]                                                        |
|                                          | Window end position selection                      | OFS0.IWDTRPES[1:0]                                                 | IWDTCR.RPES[1:0]                                                        |
| Reset output or interrupt request output | Reset output or interrupt request output selection | OFS0.IWDTRSTIRQS                                                   | IWDTRCR.RSTIRQS                                                         |
| Count stop                               | Sleep mode count stop control                      | OFS0.IWDTSLCSTP                                                    | IWDTCSTPR.SLCSTP                                                        |

# 22.4 Usage Notes

# 22.4.1 Refresh Operations

When making the settings to control the timing of refreshing, consider variations in the range of errors due to the accuracy of the PCLK and IWDTCLK and set values which ensure that refreshing is possible.

## 22.4.2 Clock Divide Ratio Setting

Satisfy the frequency of the peripheral module clock (PCLK)  $\geq 4 \times$  (the frequency of the count source after divide).

## 22.4.3 Note on Parallel Use of the Voltage Monitoring 1 Reset and IWDT Reset

When the OFS.STUPLVD1REN bit is set to 0 (the voltage monitoring 1 reset is enabled at startup) and the OFS0.IWDTRSTIRQS or IWDTRCR.RSTIRQS bit is set to 1 (the IWDT reset output is enabled), enable the voltage monitoring 1 reset at the beginning of the program according to the procedure in section 8.4, Interrupt and Reset from Voltage Monitoring 1.

# 23. Serial Communications Interface (SCIe, SCIf)

This MCU has three independent serial communications interface (SCI) channels. The SCI consists of the SCIe module (SCI1 and SCI5) and the SCIf module (SCI12).

The SCIe module (SCI1 and SCI5) can handle both asynchronous and clock synchronous serial communications.

Asynchronous serial data communications can be carried out with standard asynchronous communications chips such as a Universal Asynchronous Receiver/Transmitter (UART) or Asynchronous Communications Interface Adapter (ACIA). As an extended function in asynchronous communications mode, the SCI also supports smart card (IC card) interfaces conforming to ISO/IEC 7816-3 (standard for Identification Cards). The SCI is also supports simple SPI interfaces, and simple I<sup>2</sup>C-bus interfaces when configured for single-master systems.

The SCIf module includes the functions of the SCIe module, and supports an extended serial communication protocol formed of Start Frames and Information Frames.

In this section, "PCLK" is used to refer to PCLKB.

#### 23.1 Overview

Table 23.1 lists the specifications of the SCIe module, Table 23.2 lists the specifications of the SCIf module, and Table 23.3 lists the specifications of the individual SCI channels.

Figure 23.1 shows the block diagram of the SCIe module, and Figure 23.2 shows the block diagram of the SCIf module.

Table 23.1 SCIe Specifications (1/2)

| Item                 |                                         | Description                                                                                                                                                                                    |
|----------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Serial communication | modes                                   | <ul> <li>Asynchronous</li> <li>Clock synchronous</li> <li>Smart card interface</li> <li>Simple I<sup>2</sup>C-bus</li> <li>Simple SPI bus</li> </ul>                                           |
| Transfer speed       |                                         | Bit rate specifiable with the on-chip baud rate generator.                                                                                                                                     |
| Full-duplex communic | ations                                  | Transmitter: Continuous transmission possible using double-buffer structure.  Receiver: Continuous reception possible using double-buffer structure.                                           |
| I/O pins             |                                         | Refer to Table 23.4 to Table 23.6.                                                                                                                                                             |
| Data transfer        |                                         | Selectable as LSB first or MSB first transfer*1                                                                                                                                                |
| Interrupt sources    |                                         | Transmit end, transmit data empty, receive data full, and receive error Completion of generation of a start condition, restart condition, or stop condition (for simple I <sup>2</sup> C mode) |
| Low power consumpti  | on function                             | Module stop state can be set for each channel.                                                                                                                                                 |
| Asynchronous mode    | Data length                             | 7 or 8 bits                                                                                                                                                                                    |
|                      | Transmission stop bit                   | 1 or 2 bits                                                                                                                                                                                    |
|                      | Parity                                  | Even parity, odd parity, or no parity                                                                                                                                                          |
|                      | Receive error detection                 | Parity, overrun, and framing errors                                                                                                                                                            |
|                      | Hardware flow control                   | CTSn# and RTSn# pins can be used in controlling transmission/reception.                                                                                                                        |
|                      | Start-bit detection                     | Low level or falling edge is selectable.                                                                                                                                                       |
|                      | Break detection                         | When a framing error occurs, a break can be detected by reading the RXDn pin level directly.                                                                                                   |
|                      | Clock source                            | An internal or external clock can be selected.  Transfer rate clock input from the MTU can be used. (SCI1, SCI5)                                                                               |
|                      | Multi-processor communications function | Serial communication among multiple processors                                                                                                                                                 |
|                      | Noise cancellation                      | The signal paths from input on the RXDn pins incorporate digital noise filters.                                                                                                                |

Table 23.1 SCIe Specifications (2/2)

| Item                         |                         | Description                                                                                                                                       |
|------------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock synchronous            | Data length             | 8 bits                                                                                                                                            |
| mode                         | Receive error detection | Overrun error                                                                                                                                     |
|                              | Hardware flow control   | CTSn# and RTSn# pins can be used in controlling transmission/reception.                                                                           |
| Smart card interface mode    | Error processing        | An error signal can be automatically transmitted when detecting a parity error during reception                                                   |
|                              |                         | Data can be automatically retransmitted when receiving an error signal during transmission                                                        |
|                              | Data type               | Both direct convention and inverse convention are supported.                                                                                      |
| Simple I <sup>2</sup> C mode | Transfer format         | I <sup>2</sup> C-bus format                                                                                                                       |
|                              | Operating mode          | Master (single-master operation only)                                                                                                             |
|                              | Transfer rate           | Fast mode is supported (refer to section 23.2.9, Bit Rate Register (BRR) to set the transfer rate).                                               |
|                              | Noise cancellation      | The signal paths from input on the SSCLn and SSDAn pins incorporate digital noise filters, and the interval for noise cancellation is adjustable. |
| Simple SPI bus               | Data length             | 8 bits                                                                                                                                            |
|                              | Detection of errors     | Overrun error                                                                                                                                     |
|                              | SS input pin function   | Applying the high level to the SSn# pin can cause the output pins to enter the high-impedance state.                                              |
|                              | Clock settings          | Four kinds of settings for clock phase and clock polarity are selectable.                                                                         |

Note 1. In simple I<sup>2</sup>C mode, only MSB first is available.

Table 23.2 SCIf Specifications (1/2)

| Item                       |                                         | Description                                                                                                                                                                                    |
|----------------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Serial communication modes |                                         | <ul> <li>Asynchronous</li> <li>Clock synchronous</li> <li>Smart card interface</li> <li>Simple I<sup>2</sup>C-bus</li> <li>Simple SPI bus</li> </ul>                                           |
| Transfer speed             |                                         | Bit rate specifiable with the on-chip baud rate generator.                                                                                                                                     |
| Full-duplex con            | nmunications                            | Transmitter: Continuous transmission possible using double-buffer structure.  Receiver: Continuous reception possible using double-buffer structure.                                           |
| I/O pins                   |                                         | Refer to Table 23.4 to Table 23.7.                                                                                                                                                             |
| Data transfer              |                                         | Selectable as LSB first or MSB first transfer*1                                                                                                                                                |
| Interrupt sources          |                                         | Transmit end, transmit data empty, receive data full, and receive error Completion of generation of a start condition, restart condition, or stop condition (for simple I <sup>2</sup> C mode) |
| Low power con              | sumption function                       | Module stop state can be set.                                                                                                                                                                  |
| Asynchronous               | Data length                             | 7 or 8 bits                                                                                                                                                                                    |
| mode                       | Transmission stop bit                   | 1 or 2 bits                                                                                                                                                                                    |
|                            | Parity                                  | Even parity, odd parity, or no parity                                                                                                                                                          |
|                            | Receive error detection                 | Parity, overrun, and framing errors                                                                                                                                                            |
|                            | Hardware flow control                   | CTSn# and RTSn# pins can be used in controlling transmission/reception.                                                                                                                        |
|                            | Start-bit detection                     | Low level or falling edge is selectable.                                                                                                                                                       |
|                            | Break detection                         | When a framing error occurs, a break can be detected by reading the RXDn pin level directly.                                                                                                   |
|                            | Clock source                            | An internal or external clock can be selected.  Transfer rate clock input from the MTU can be used. (SCI12)                                                                                    |
|                            | Multi-processor communications function | Serial communication among multiple processors                                                                                                                                                 |
|                            | Noise cancellation                      | The signal paths from input on the RXDn pins incorporate digital noise filters.                                                                                                                |

Table 23.2 SCIf Specifications (2/2)

| Item                      |                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|---------------------------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Clock                     | Data length              | 8 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| synchronous<br>mode       | Receive error detection  | Overrun error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| mode                      | Hardware flow control    | CTSn# and RTSn# pins can be used in controlling transmission/reception.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Smart card interface mode | Error processing         | An error signal can be automatically transmitted when detecting a parity error during reception                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|                           |                          | Data can be automatically retransmitted when receiving an error signal during transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|                           | Data type                | Both direct convention and inverse convention are supported.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Simple I <sup>2</sup> C   | Transfer format          | I <sup>2</sup> C-bus format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| mode                      | Operating mode           | Master (single-master operation only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|                           | Transfer rate            | Fast mode is supported (refer to section 23.2.9, Bit Rate Register (BRR) to set the transfer rate).                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                           | Noise cancellation       | The signal paths from input on the SSCLn and SSDAn pins incorporate digital noise filters, and the interval for noise cancellation is adjustable.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| Simple SPI                | Data length              | 8 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| bus                       | Detection of errors      | Overrun error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|                           | SS input pin function    | Applying the high level to the SSn# pin can cause the output pins to enter the high-impedance state.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|                           | Clock settings           | Four kinds of settings for clock phase and clock polarity are selectable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Extended serial mode      | Start Frame transmission | <ul> <li>Output of a low level as the Break Field over a specified width and generation of interrupts on completion</li> <li>Detection of bus collisions and the generation of interrupts on detection</li> </ul>                                                                                                                                                                                                                                                                                                                                            |  |  |
|                           | Start Frame reception    | <ul> <li>Detection of the Break Field low width and generation of an interrupt on detection</li> <li>Comparison of Control Fields 0 and 1 and generation of an interrupt when the two match</li> <li>Two kinds of data for comparison (primary and secondary) can be set in Control Field 1.</li> <li>A priority interrupt bit can be set in Control Field 1.</li> <li>Handling of Start Frames that do not include a Break Field</li> <li>Handling of Start Frames that do not include a Control Field</li> <li>Function for measuring bit rates</li> </ul> |  |  |
|                           | I/O control function     | <ul> <li>Selectable polarity for TXDX12 and RXDX12 signals</li> <li>Selection of a digital filter for the RXDX12 signal</li> <li>Half-duplex operation employing RXDX12 and TXDX12 signals multiplexed on the same pin</li> <li>Selectable timing for the sampling of data received through RXDX12</li> <li>Signals received on RXDX12 can be passed though to SCIe when the extended serial mode control section is off.</li> </ul>                                                                                                                         |  |  |
|                           | Timer function           | Usable as a reloading timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |

Note 1. In simple I<sup>2</sup>C mode, only MSB first is available.

Table 23.3 Functions of SCI Channels

| Item                         | SCI1          | SCI5          | SCI12     |  |
|------------------------------|---------------|---------------|-----------|--|
| Asynchronous mode            | Available     | Available     | Available |  |
| Clock synchronous mode       | Available     | Available     | Available |  |
| Smart card interface mode    | Available     | Available     | Available |  |
| Simple I <sup>2</sup> C mode | Available     | Available     | Available |  |
| Simple SPI mode              | Available     | Available     | Available |  |
| Extended serial mode         | Not available | Not available | Available |  |
| MTU clock input              | Available     | Available     | Available |  |



Figure 23.1 Block Diagram of SCIe (SCI1 and SCI5)



Figure 23.2 Block Diagram of SCIf (SCI12)

Table 23.4 to Table 23.7 list the pin configuration of the SCIs for the individual modes.

Table 23.4 SCI Pin Configuration in Asynchronous Mode and Clock Synchronous Mode

| Channel | Pin Name      | I/O    | Function                                  |
|---------|---------------|--------|-------------------------------------------|
| SCI1    | SCK1          | I/O    | SCI1 clock input/output                   |
|         | RXD1          | Input  | SCI1 receive data input                   |
|         | TXD1          | Output | SCI1 transmit data output                 |
|         | CTS1#/RTS1#   | I/O    | SCI1 transfer start control input/output  |
| SCI5    | SCK5          | I/O    | SCI5 clock input/output                   |
|         | RXD5          | Input  | SCI5 receive data input                   |
|         | TXD5          | Output | SCI5 transmit data output                 |
|         | CTS5#/RTS5#   | I/O    | SCI5 transfer start control input/output  |
| SCI12   | SCK12         | I/O    | SCI12 clock input/output                  |
|         | RXD12 Input   |        | SCI12 receive data input                  |
|         | TXD12         | Output | SCI12 transmit data output                |
|         | CTS12#/RTS12# | I/O    | SCI12 transfer start control input/output |

Table 23.5 SCI Pin Configuration in Simple I<sup>2</sup>C Mode

| Channel | Pin Name | I/O | Function                                  |  |
|---------|----------|-----|-------------------------------------------|--|
| SCI1    | SSCL1    | I/O | SCI1 I <sup>2</sup> C clock input/output  |  |
|         | SSDA1    | I/O | SCI1 I <sup>2</sup> C data input/output   |  |
| SCI5    | SSCL5    | I/O | SCI5 I <sup>2</sup> C clock input/output  |  |
|         | SSDA5    | I/O | SCI5 I <sup>2</sup> C data input/output   |  |
| SCI12   | SSCL12   | I/O | SCI12 I <sup>2</sup> C clock input/output |  |
|         | SSDA12   | I/O | SCI12 I <sup>2</sup> C data input/output  |  |

Table 23.6 SCI Pin Configuration in Simple SPI Mode

| Channel | Pin Name | I/O   | Function                                |  |
|---------|----------|-------|-----------------------------------------|--|
| SCI1    | SCK1     | I/O   | SCI1 clock input/output                 |  |
|         | SMISO1   | I/O   | SCI1 slave transmit data input/output   |  |
|         | SMOSI1   | I/O   | SCI1 master transmit data input/output  |  |
|         | SS1#     | Input | SCI1 chip select input                  |  |
| SCI5    | SCK5     | I/O   | SCI5 clock input/output                 |  |
|         | SMISO5   | I/O   | SCI5 slave transmit data input/output   |  |
|         | SMOSI5   | I/O   | SCI5 master transmit data input/output  |  |
|         | SS5#     | Input | SCI5 chip select input                  |  |
| SCI12   | SCK12    | I/O   | SCI12 clock input/output                |  |
|         | SMISO12  | I/O   | SCI12 slave transmit data input/output  |  |
|         | SMOSI12  | I/O   | SCI12 master transmit data input/output |  |
|         | SS12#    | Input | SCI12 chip select input                 |  |

Table 23.7 SCI Pin Configuration in Extended Serial Mode

| Channel | Pin Name | I/O    | Function                         |
|---------|----------|--------|----------------------------------|
| SCI12   | RXDX12   | Input  | SCI12 receive data input         |
|         | TXDX12   | Output | SCI12 transmit data output       |
|         | SIOX12   | I/O    | SCI12 transfer data input/output |



## 23.2 Register Descriptions

# 23.2.1 Receive Shift Register (RSR)

RSR is a shift register which is used to receive serial data input from the RXDn pin and converts it into parallel data.

When one frame of data has been received, it is automatically transferred to the RDR register.

The RSR register cannot be directly accessed by the CPU.

# 23.2.2 Receive Data Register (RDR)

Address(es): SCI1.RDR 0008 A025h, SCI5.RDR 0008 A0A5h, SCI12.RDR 0008 B305h



RDR is an 8-bit register that stores receive data.

When one frame of serial data has been received, the received serial data is transferred from RSR to RDR. Then the RSR register can receive the next data.

Since RSR and RDR function as a double buffer in this way, continuous receive operations can be performed.

Read RDR only once after a receive data full interrupt (RXI) has occurred. Note that if next one frame of data is received before reading receive data from RDR, an overrun error occurs.

RDR cannot be written to by the CPU.

## 23.2.3 Transmit Data Register (TDR)

Address(es): SCI1.TDR 0008 A023h, SCI5.TDR 0008 A0A3h, SCI12.TDR 0008 B303h



TDR is an 8-bit register that stores transmit data.

When the SCI detects that the TSR register is empty, it transfers the transmit data written in the TDR register to the TSR register and starts transmission.

The double-buffered structures of the TDR register and the TSR register enable continuous serial transmission. If the next transmit data has already been written to the TDR register when one frame of data is transmitted, the SCI transfers the written data to the TSR register to continue transmission.

The CPU is able to read from or write to the TDR register at any time. Only write transmit data to the TDR register once after each instance of the transmit data empty interrupt (TXI).

## 23.2.4 Transmit Shift Register (TSR)

TSR is a shift register that transmits serial data.

To perform serial data transmission, the SCI first automatically transfers transmit data from TDR to TSR, and then sends the data to the TXDn pin.

TSR cannot be directly accessed by the CPU.



# 23.2.5 Serial Mode Register (SMR)

Note: Some bits in SMR have different functions in smart card interface mode and non-smart card interface mode.

## (1) Non-Smart Card Interface Mode (SCMR.SMIF = 0)

Address(es): SCI1.SMR 0008 A020h, SCI5.SMR 0008 A0A0h, SCI12.SMR 0008 B300h



| Bit    | Symbol   | Bit Name             | Description                                                                                                                                                                                                                                                                          | R/W               |
|--------|----------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| b1, b0 | CKS[1:0] | Clock Select         | b1 b0<br>0 0: PCLK (n = 0)*1<br>0 1: PCLK/4 (n = 1)*1<br>1 0: PCLK/16 (n = 2)*1<br>1 1: PCLK/64 (n = 3)*1                                                                                                                                                                            | R/W*4             |
| b2     | MP       | Multi-Processor Mode | (Valid only in asynchronous mode) 0: Multi-processor communications function is disabled 1: Multi-processor communications function is enabled                                                                                                                                       | R/W* <sup>4</sup> |
| b3     | STOP     | Stop Bit Length      | (Valid only in asynchronous mode) 0: 1 stop bit 1: 2 stop bits                                                                                                                                                                                                                       | R/W*4             |
| b4     | PM       | Parity Mode          | (Valid only when the PE bit is 1) 0: Selects even parity 1: Selects odd parity                                                                                                                                                                                                       | R/W*4             |
| b5     | PE       | Parity Enable        | <ul> <li>(Valid only in asynchronous mode)</li> <li>When transmitting</li> <li>0: Parity bit addition is not performed</li> <li>1: The parity bit is added</li> <li>When receiving</li> <li>0: Parity bit checking is not performed</li> <li>1: The parity bit is checked</li> </ul> | R/W*4             |
| b6     | CHR      | Character Length     | (Valid only in asynchronous mode) 0: Selects 8 bits as the data length* <sup>2</sup> 1: Selects 7 bits as the data length* <sup>3</sup>                                                                                                                                              | R/W* <sup>4</sup> |
| b7     | СМ       | Communications Mode  | 0: Asynchronous mode or simple I <sup>2</sup> C mode<br>1: Clock synchronous mode or simple SPI mode                                                                                                                                                                                 | R/W*4             |

Note 1. n is the decimal notation of the value of n in the BRR register (refer to section 23.2.9, Bit Rate Register (BRR)).

#### CKS[1:0] Bits (Clock Select)

These bits select the clock source for the on-chip baud rate generator.

For the relation between the settings of these bits and the baud rate, refer to section 23.2.9, Bit Rate Register (BRR).

#### MP Bit (Multi-Processor Mode)

Disables/enables the multi-processor communications function. The settings of the PE bit and PM bit are invalid in multi-processor mode.

## STOP Bit (Stop Bit Length)

Selects the stop bit length in transmission.

In reception, only the first stop bit is checked regardless of this bit setting. If the second stop bit is 0, it is treated as the start bit of the next transmit frame.



Note 2. In other than asynchronous mode, this bit setting is invalid and a fixed data length of 8 bits is used.

Note 3. LSB first is fixed and the MSB (bit 7) in the TDR register is not transmitted in transmission.

Note 4. Writable only when TE in SCR = 0 and RE in SCR = 0 (both serial transmission and reception are disabled).

# PM Bit (Parity Mode)

Selects the parity mode (even or odd) for transmission and reception.

The setting of the PM bit is invalid in multi-processor mode.

# PE Bit (Parity Enable)

When this bit is set to 1, the parity bit is added to transmit data, and the parity bit is checked in reception. Irrespective of the setting of the PE bit, the parity bit is not added or checked in multi-processor format.

# **CHR Bit (Character Length)**

Selects the data length for transmission and reception.

In other than asynchronous mode, a fixed data length of 8 bits is used.



## (2) Smart Card Interface Mode (SCMR.SMIF = 1)

Address(es): SMCI1.SMR 0008 A020h, SMCI5.SMR 0008 A0A0h, SMCI12.SMR 0008 B300h



| Bit    | Symbol   | Bit Name               | Description                                                                                                                                                    | R/W               |
|--------|----------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| b1, b0 | CKS[1:0] | Clock Select           | b1 b0<br>0 0: PCLK (n = 0)*1<br>0 1: PCLK/4 (n = 1)*1<br>1 0: PCLK/16 (n = 2)*1<br>1 1: PCLK/64 (n = 3)*1                                                      | R/W* <sup>2</sup> |
| b3, b2 | BCP[1:0] | Base Clock Pulse       | Selects the number of base clock cycles in combination with the SCMR.BCP2 bit.  Table 23.8 lists the combinations of the SCMR.BCP2 bit and SMR.BCP[1:0] bits.  | R/W*2             |
| b4     | PM       | Parity Mode            | (Valid only when the PE bit is 1) 0: Selects even parity 1: Selects odd parity                                                                                 | R/W*2             |
| b5     | PE       | Parity Enable          | When this bit is set to 1, a parity bit is added to transmit data, and the parity of received data is checked. Set this bit to 1 in smart card interface mode. | R/W* <sup>2</sup> |
| b6     | BLK      | Block Transfer<br>Mode | Normal mode operation     Block transfer mode operation                                                                                                        | R/W*2             |
| b7     | GM       | GSM Mode               | Normal mode operation     GSM mode operation                                                                                                                   | R/W*2             |

Note 1. n is the decimal notation of the value of n in BRR (refer to section 23.2.9, Bit Rate Register (BRR)).

Note 2. Writable only when TE in SCR = 0 and RE in SCR = 0 (both serial transmission and reception are disabled).

### CKS[1:0] Bits (Clock Select)

These bits select the clock source for the on-chip baud rate generator.

For the relationship between the settings of these bits and the baud rate, refer to section 23.2.9, Bit Rate Register (BRR).

#### BCP[1:0] Bits (Base Clock Pulse)

These bits select the number of base clock cycles in a 1-bit data transfer time in smart card interface mode.

Set these bits in combination with the SCMR.BCP2 bit.

For details, refer to section 23.6.4, Receive Data Sampling Timing and Reception Margin.

Table 23.8 Combinations of the SCMR.BCP2 Bit and SMR.BCP[1:0] Bits

| SCMR.BCP2 Bit | SMR.BCP[1:0] Bits |   | Number of Base Clock Cycles for 1-Bit Transfer Period |
|---------------|-------------------|---|-------------------------------------------------------|
| 0             | 0                 | 0 | 93 clock cycles (S = 93)*1                            |
| 0             | 0                 | 1 | 128 clock cycles (S = 128)*1                          |
| 0             | 1                 | 0 | 186 clock cycles (S = 186)*1                          |
| 0             | 1                 | 1 | 512 clock cycles (S = 512)*1                          |
| 1             | 0                 | 0 | 32 clock cycles (S = 32)*1 (Initial Value)            |
| 1             | 0                 | 1 | 64 clock cycles (S = 64)*1                            |
| 1             | 1                 | 0 | 372 clock cycles (S = 372)*1                          |
| 1             | 1                 | 1 | 256 clock cycles (S = 256)*1                          |
|               |                   |   |                                                       |

Note 1. S is the value of S in BRR (refer to section 23.2.9, Bit Rate Register (BRR)).



#### PM Bit (Parity Mode)

Selects the parity mode for transmission and reception (even or odd).

For details on the usage of this bit in smart card interface mode, refer to section 23.6.2, Data Format (Except in Block Transfer Mode).

#### PE Bit (Parity Enable)

Set the PE bit to 1.

The parity bit is added to transmit data before transmission, and the parity bit is checked in reception.

## **BLK Bit (Block Transfer Mode)**

Setting this bit to 1 allows block transfer mode operation.

For details, refer to section 23.6.3, Block Transfer Mode.

# **GM Bit (GSM Mode)**

Setting this bit to 1 allows GSM mode operation.

In GSM mode, the SSR.TEND flag set timing is put forward to 11.0 etu (elementary time unit = 1-bit transfer time) from the start and the clock output control function is appended. For details, refer to section 23.6.6, Serial Data Transmission (Except in Block Transfer Mode) and section 23.6.8, Clock Output Control.



# 23.2.6 Serial Control Register (SCR)

Note: Some bits in the SCR register have different functions in smart card interface mode and non-smart card interface mode.

# (1) Non-Smart Card Interface Mode (SCMR.SMIF = 0)

Address(es): SCI1.SCR 0008 A022h, SCI5.SCR 0008 A0A2h, SCI12.SCR 0008 B302h



| Bit    | Symbol   | Bit Name                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R/W   |
|--------|----------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| b1, b0 | CKE[1:0] | Clock Enable                        | <ul> <li>(Asynchronous mode)</li> <li>b1 b0</li> <li>0 0: On-chip baud rate generator             The SCKn pin is available for use as an I/O port according to the I/O port settings.</li> <li>0 1: On-chip baud rate generator             The clock with the same frequency as the bit rate is output from the SCKn pin.</li> <li>1 x: External clock or MTU clock             • The clock with a frequency 16 times the bit rate should be input from the SCKn pin. Input a clock signal with a frequency eight times the bit rate when the SEMR.ABCS bit is 1.             • The MTU clock can be used.             The SCKn pin is available for use as an I/O port according to the I/O port settings when the MTU clock is used.</li> <li>(Clock synchronous mode)</li> <li>b1 b0</li> <li>0 x: Internal clock             The SCKn pin functions as the clock output pin.</li> <li>1 x: External clock             The SCKn pin functions as the clock input pin.</li> </ul> | R/W*1 |
| b2     | TEIE     | Transmit End Interrupt Enable       | 0: A TEI interrupt request is disabled 1: A TEI interrupt request is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R/W   |
| b3     | MPIE     | Multi-Processor Interrupt<br>Enable | <ul> <li>(Valid in asynchronous mode when SMR.MP = 1)</li> <li>0: Normal reception</li> <li>1: When the data with the multi-processor bit set to 0 is received, the data is not read, and setting the status flags ORER and FER in SSR to 1 is disabled. When the data with the multi-processor bit set to 1 is received, the MPIE bit is automatically cleared to 0, and normal reception is resumed.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W   |
| b4     | RE       | Receive Enable                      | Serial reception is disabled     Serial reception is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R/W*2 |
| b5     | TE       | Transmit Enable                     | Serial transmission is disabled     Serial transmission is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W*2 |
| b6     | RIE      | Receive Interrupt Enable            | RXI and ERI interrupt requests are disabled     RXI and ERI interrupt requests are enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R/W   |
| b7     | TIE      | Transmit Interrupt Enable           | O: A TXI interrupt request is disabled     1: A TXI interrupt request is enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W   |

## x: Don't care

Note 1. Writable only when TE = 0 and RE = 0.

Note 2. 1 can be written only when TE = 0 and RE = 0, while the SMR.CM bit is 1. After setting TE or RE to 1, only 0 can be written to TE and RE. While the SMR.CM bit is 0 and the SIMR1.IICM bit is 0, writing is enabled under any condition.

### CKE[1:0] Bits (Clock Enable)

These bits select the clock source and SCKn pin function.

The combination of the settings of these bits and of the SEMR.ACS0 bit sets the internal MTU clock.

## **TEIE Bit (Transmit End Interrupt Enable)**

Enables or disables a TEI interrupt request.

A TEI interrupt request is disabled by setting the TEIE bit to 0.

In simple I<sup>2</sup>C mode, the TEI is allocated to the interrupt on completion of issuing a start, restart, or stop condition (STI). In this case, the TEIE bit can be used to enable or disable the STI.

#### **MPIE Bit (Multi-Processor Interrupt Enable)**

When this bit is set to 1 and the data with the multi-processor bit set to 0 is received, the data is not read and setting the status flags ORER and FER in the SSR register to 1 is disabled. When the data with the multi-processor bit set to 1 is received, the MPIE bit is automatically cleared to 0, and normal reception is resumed. For details, refer to section 23.4, Multi-Processor Communications Function.

When the data with the multi-processor bit set to 0 is received, the receive data is not transferred from the RSR to the RDR, a receive error is not detected, and setting the flags ORER and FER to 1 is disabled.

When the data with the multi-processor bit set to 1 is received, the MPB bit is set to 1, the MPIE bit is automatically cleared to 0, the RXI and ERI interrupt requests are enabled (if the SCR.RIE bit is set to 1), and setting the flags ORER and FER to 1 is enabled.

Set the MPIE bit to 0 if multi-processor communications function is not to be used.

### **RE Bit (Receive Enable)**

Enables or disables serial reception.

When this bit is set to 1, serial reception is started by detecting the start bit in asynchronous mode or the synchronous clock input in clock synchronous mode. Note that the SMR register should be set prior to setting the RE bit to 1 in order to designate the reception format.

Even if reception is halted by setting the RE bit to 0, the ORER, FER, PER, and RDRF flags in the SSR register are not affected and the previous value is retained.

#### TE Bit (Transmit Enable)

Enables or disables serial transmission.

When this bit is set to 1, serial transmission is started by writing transmit data to TDR. Note that SMR should be set prior to setting the TE bit to 1 in order to designate the transmission format.

#### **RIE Bit (Receive Interrupt Enable)**

Enables or disables RXI and ERI interrupt requests.

An RXI interrupt request is disabled by setting the RIE bit to 0.

An ERI interrupt request can be canceled by reading 1 from the ORER, FER, or PER flag in the SSR register and then setting the flag to 0, or setting the RIE bit to 0.

#### **TIE Bit (Transmit Interrupt Enable)**

Enables or disables TXI interrupt request.

A TXI interrupt request is disabled by setting the TIE bit to 0.



## (2) Smart Card Interface Mode (SCMR.SMIF = 1)

Address(es): SMCI1.SCR 0008 A022h, SMCI5.SCR 0008 A0A2h, SMCI12.SCR 0008 B302h



| Bit    | Symbol   | Bit Name                         | Description                                                                                                                                                                 | R/W               |
|--------|----------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| b1, b0 | CKE[1:0] | Clock Enable                     | When SMR.GM = 0  b1 b0 0 0: Output disabled (The SCKn pin is available for use as an I/O port according to the I/O port settings.)  1: Clock output x: (Setting prohibited) | R/W*1             |
|        |          |                                  | <ul> <li>When SMR.GM = 1</li> <li>b1 b0</li> <li>0 0: Output fixed low</li> <li>x 1: Clock output</li> <li>1 0: Output fixed high</li> </ul>                                |                   |
| b2     | TEIE     | Transmit End Interrupt Enable    | This bit should be 0 in smart card interface mode.                                                                                                                          | R/W               |
| b3     | MPIE     | Multi-Processor Interrupt Enable | This bit should be 0 in smart card interface mode.                                                                                                                          | R/W               |
| b4     | RE       | Receive Enable                   | Serial reception is disabled     Serial reception is enabled                                                                                                                | R/W* <sup>2</sup> |
| b5     | TE       | Transmit Enable                  | Serial transmission is disabled     Serial transmission is enabled                                                                                                          | R/W*2             |
| b6     | RIE      | Receive Interrupt Enable         | RXI and ERI interrupt requests are disabled     RXI and ERI interrupt requests are enabled                                                                                  | R/W               |
| b7     | TIE      | Transmit Interrupt Enable        | O: A TXI interrupt request is disabled     1: A TXI interrupt request is enabled                                                                                            | R/W               |

x: Don't care

Note 2. 1 can be written only when TE = 0 and RE = 0. After setting TE or RE to 1, only 0 can be written in TE and RE.

For details on interrupt requests, refer to section 23.11, Interrupt Sources.

## CKE[1:0] Bits (Clock Enable)

These bits control the clock output from the SCKn pin.

In GSM mode, clock output can be dynamically switched. For details, refer to section 23.6.8, Clock Output Control.

# **TEIE Bit (Transmit End Interrupt Enable)**

This bit should be 0 in smart card interface mode.

## **MPIE Bit (Multi-Processor Interrupt Enable)**

This bit should be 0 in smart card interface mode.

Note 1. Writable only when TE = 0 and RE = 0.

### RE Bit (Receive Enable)

Enables or disables serial reception.

When this bit is set to 1, serial reception is started by detecting the start bit. Note that the SMR register should be set prior to setting the RE bit to 1 in order to designate the reception format.

Even if reception is halted by setting the RE bit to 0, the ORER, FER, and PER flags in the SSR register are not affected and the previous value is retained.

#### TE Bit (Transmit Enable)

Enables or disables serial transmission.

When this bit is set to 1, serial transmission is started by writing transmit data to the TDR register. Note that the SMR register should be set prior to setting the TE bit to 1 in order to designate the transmission format.

#### **RIE Bit (Receive Interrupt Enable)**

Enables or disables RXI and ERI interrupt requests.

An RXI interrupt request is disabled by setting the RIE bit to 0.

An ERI interrupt request can be canceled by reading 1 from the ORER, FER, or PER flag in the SSR register and then setting the flag to 0, or setting the RIE bit to 0.

#### **TIE Bit (Transmit Interrupt Enable)**

Enables or disables TXI interrupt request.

A TXI interrupt request is disabled by setting the TIE bit to 0.

# 23.2.7 Serial Status Register (SSR)

Some bits in the SSR register have different functions in smart card interface mode and non-smart card interface mode.

## (1) Non-Smart Card Interface Mode (SCMR.SMIF = 0)

Address(es): SCI1.SSR 0008 A024h, SCI5.SSR 0008 A0A4h, SCI12.SSR 0008 B304h



| Bit | Symbol | Bit Name                     | Description                                                                                                             | R/W         |
|-----|--------|------------------------------|-------------------------------------------------------------------------------------------------------------------------|-------------|
| b0  | MPBT   | Multi-Processor Bit Transfer | Sets the multi-processor bit for adding to the transmission frame 0: Data transmission cycles 1: ID transmission cycles | R/W         |
| b1  | MPB    | Multi-Processor              | Value of the multi-processor bit in the reception frame 0: Data transmission cycles 1: ID transmission cycles           | R           |
| b2  | TEND   | Transmit End Flag            | O: A character is being transmitted.     Character transfer has been completed.                                         | R           |
| b3  | PER    | Parity Error Flag            | No parity error occurred     A parity error has occurred                                                                | R/(W)<br>*1 |
| b4  | FER    | Framing Error Flag           | No framing error occurred     A framing error has occurred                                                              | R/(W)<br>*1 |
| b5  | ORER   | Overrun Error Flag           | No overrun error occurred     An overrun error has occurred                                                             | R/(W)<br>*1 |
| b6  | RDRF   | Receive Data Full Flag       | No valid data is held in the RDR register     Received data is held in the RDR register                                 | R/(W)<br>*2 |
| b7  | TDRE   | Transmit Data Empty Flag     | Data to be transmitted is held in the TDR register     No data is held in the TDR register                              | R/(W)<br>*2 |

Note 1. Only 0 can be written to this bit, to clear the flag. To clear this flag, confirm that the flag is 1 and then set it to 0.

#### MPB Bit (Multi-Processor)

Holds the value of the multi-processor bit in the reception frame. This bit does not change when the SCR.RE bit is 0.

#### **TEND Flag (Transmit End Flag)**

Indicates completion of transmission.

[Setting conditions]

- When the SCR.TE bit is set to 0 (serial transmission is disabled)
  When the SCR.TE bit is changed from 0 to 1, the TEND flag is not affected and retains the value 1.
- When the TDR register is not updated at the time of transmission of the tail-end bit of a character being transmitted [Clearing condition]
  - When transmit data are written to the TDR register while the SCR.TE bit is 1
     When setting the TEND flag to 0 to complete the interrupt handling, refer to section 14.4.1.2, Operation of Status Flags for Level-Detected Interrupts.

Note 2. Write 1 when writing is necessary.

#### PER Flag (Parity Error Flag)

Indicates that a parity error has occurred during reception in asynchronous mode and the reception ends abnormally. [Setting condition]

When a parity error is detected during reception
 Although receive data when the parity error occurs is transferred to RDR, no RXI interrupt request occurs. Note that when the PER flag is being set to 1, the subsequent receive data is not transferred to RDR.

#### [Clearing condition]

• When 0 is written to PER after reading PER = 1

When setting the PER flag to 0 to complete the interrupt handling, refer to section 14.4.1.2, Operation of Status Flags for Level-Detected Interrupts.

Even when the SCR.RE bit is set to 0 (serial reception is disabled), the PER flag is not affected and retains its previous value.

## **FER Flag (Framing Error Flag)**

Indicates that a framing error has occurred during reception in asynchronous mode and the reception ends abnormally. [Setting condition]

• When the stop bit is 0

In 2-stop-bit mode, only the first stop bit is checked whether it is 1 but the second stop bit is not checked. Note that although receive data when the framing error occurs is transferred to RDR, no RXI interrupt request occurs. In addition, when the FER flag is being set to 1, the subsequent receive data is not transferred to RDR.

#### [Clearing condition]

• When 0 is written to FER after reading FER = 1

When setting the FER flag to 0 to complete the interrupt handling, refer to section 14.4.1.2, Operation of Status Flags for Level-Detected Interrupts.

Even when the SCR.RE bit is set to 0, the FER flag is not affected and retains its previous value.

#### **ORER Flag (Overrun Error Flag)**

Indicates that an overrun error has occurred during reception and the reception ends abnormally. [Setting condition]

• When the next data is received before receive data is read from RDR
In RDR, receive data prior to an overrun error occurrence is retained, but data received after the overrun error occurrence is lost. When the ORER flag is set to 1, subsequent serial reception cannot be performed. Note that, in clock synchronous mode, serial transmission also cannot continue.

### [Clearing condition]

• When 0 is written to ORER after reading ORER = 1

When setting the ORER flag to 0 to complete the interrupt handling, refer to section 14.4.1.2, Operation of Status Flags for Level-Detected Interrupts.

Even when the SCR.RE bit is set to 0, the ORER flag is not affected and retains its previous value.

#### RDRF Flag (Receive Data Full Flag)

Indicates whether the RDR register has received data.

[Setting condition]

• When data has been received normally, and transferred from RSR to RDR

[Clearing condition]

• When data is read from RDR



# **TDRE Flag (Transmit Data Empty Flag)**

Indicates whether the TDR register has data to be transmitted.

[Setting condition]

• When data is transferred from TDR to TSR

[Clearing condition]

• When data is written to TDR



## (2) Smart Card Interface Mode (SCMR.SMIF = 1)

Address(es): SMCI1.SSR 0008 A024h, SMCI5.SSR 0008 A0A4h, SMCI12.SSR 0008 B304h



| Bit | Symbol | Bit Name                     | Description                                                                                | R/W         |
|-----|--------|------------------------------|--------------------------------------------------------------------------------------------|-------------|
| b0  | MPBT   | Multi-Processor Bit Transfer | This bit should be set to 0 in smart card interface mode.                                  | R/W         |
| b1  | MPB    | Multi-Processor              | This bit is not used in smart card interface mode. It should be set to 0.                  | R           |
| b2  | TEND   | Transmit End Flag            | O: A character is being transmitted.     Character transfer has been completed.            | R           |
| b3  | PER    | Parity Error Flag            | No parity error occurred     A parity error has occurred                                   | R/(W)<br>*1 |
| b4  | ERS    | Error Signal Status Flag     | Cow error signal not responded     Low error signal responded                              | R/(W)<br>*1 |
| b5  | ORER   | Overrun Error Flag           | No overrun error occurred     An overrun error has occurred                                | R/(W)<br>*1 |
| b6  | RDRF   | Receive Data Full Flag       | 0: No valid data is held in the RDR register 1: Received data is held in the RDR register  | R/(W)<br>*2 |
| b7  | TDRE   | Transmit Data Empty Flag     | Data to be transmitted is held in the TDR register     No data is held in the TDR register | R/(W)<br>*2 |

Note 1. Only 0 can be written to this bit, to clear the flag. To clear this flag, confirm that the flag is 1 and then set it to 0.

#### **TEND Flag (Transmit End Flag)**

With no error signal from the receiving side, this bit is set to 1 when further data for transfer is ready to be transferred to the TDR register.

[Setting conditions]

- When the SCR.TE bit = 0 (serial transmission is disabled)
  When the SCR.TE bit is changed from 0 to 1, the TEND flag is not affected and retains the value 1.
- When a specified period has elapsed after the latest transmission of 1 byte, the ERS flag is 0, and the TDR register is not updated

The set timing is determined by register settings as listed below.

When SMR.GM = 0 and SMR.BLK = 0, 12.5 etu after the start of transmission

When SMR.GM = 0 and SMR.BLK = 1, 11.5 etu after the start of transmission

When SMR.GM = 1 and SMR.BLK = 0, 11.0 etu after the start of transmission

When SMR.GM = 1 and SMR.BLK = 1, 11.0 etu after the start of transmission

#### [Clearing condition]

When transmit data are written to the TDR register while the SCR.TE bit is 1
 When setting the TEND flag to 0 to complete the interrupt handling, refer to section 14.4.1.2, Operation of Status Flags for Level-Detected Interrupts.

Note 2. Write 1 when writing is necessary.

### PER Flag (Parity Error Flag)

Indicates that a parity error has occurred during reception in asynchronous mode and the reception ends abnormally. [Setting condition]

When a parity error is detected during reception
 Although receive data when the parity error occurs is transferred to RDR, no RXI interrupt request occurs. Note that when the PER flag is being set to 1, the subsequent receive data is not transferred to RDR.

#### [Clearing condition]

• When 0 is written to PER after reading PER = 1

When setting the PER flag to 0 to complete the interrupt handling, refer to section 14.4.1.2, Operation of Status Flags for Level-Detected Interrupts.

Even when the SCR.RE bit is set to 0 (serial reception is disabled), the PER flag is not affected and retains its previous value.

## **ERS Flag (Error Signal Status Flag)**

[Setting condition]

• When a low error signal is sampled

[Clearing condition]

• When 0 is written to ERS after reading ERS = 1

When setting the ERS flag to 0 to complete the interrupt handling, refer to section 14.4.1.2, Operation of Status Flags for Level-Detected Interrupts.

Even when the SCR.RE bit is set to 0, the ERS flag is not affected and retains its previous value.

#### **ORER Flag (Overrun Error Flag)**

Indicates that an overrun error has occurred during reception and the reception ends abnormally.

[Setting condition]

When the next data is received before receive data is read from RDR
 In RDR, the receive data prior to an overrun error occurrence is retained, but data received following the overrun error occurrence is lost. When the ORER flag is set to 1, subsequent serial reception cannot be performed.

[Clearing condition]

• When 0 is written to ORER after reading ORER = 1

When setting the ORER flag to 0 to complete the interrupt handling, refer to section 14.4.1.2, Operation of Status Flags for Level-Detected Interrupts.

Even when the SCR.RE bit is set to 0, the ORER flag is not affected and retains its previous value.

### RDRF Flag (Receive Data Full Flag)

Indicates whether the RDR register has received data.

[Setting condition]

• When data has been received normally, and transferred from RSR to RDR

[Clearing condition]

• When data is read from RDR

## **TDRE Flag (Transmit Data Empty Flag)**

Indicates whether the TDR register has data to be transmitted.

[Setting condition]

• When data is transferred from TDR to TSR

[Clearing condition]

• When data is written to TDR



# 23.2.8 Smart Card Mode Register (SCMR)

Address(es): SMCI1.SCMR 0008 A026h, SMCI5.SCMR 0008 A0A6h, SMCI12.SCMR 0008 B306h



| Bit      | Symbol | Bit Name                                        | Description                                                                                                                                                                                                                                                                                          | R/W               |
|----------|--------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| b0       | SMIF   | Smart Card Interface Mode<br>Select             | O: Non-smart card interface mode (Asynchronous mode, clock synchronous mode, simple SPI mode, or simple I <sup>2</sup> C mode)  1: Smart card interface mode                                                                                                                                         | R/W*1             |
| b1       | _      | Reserved                                        | This bit is read as 1. The write value should be 1.                                                                                                                                                                                                                                                  | R/W               |
| b2       | SINV   | Transmitted/Received Data<br>Invert             | O: TDR contents are transmitted as they are. Receive data is stored as it is in RDR.  1: TDR contents are inverted before being transmitted. Receive data is stored in inverted form in RDR.                                                                                                         | R/W*1             |
| b3       | SDIR   | Transmitted/Received Data<br>Transfer Direction | This bit can be used in the following modes.  • Smart card interface mode  • Asynchronous mode (multi-processor mode)  • Clock synchronous mode  • Simple SPI mode  Set this bit to 1 if operation is to be in simple I <sup>2</sup> C mode.  0: Transfer with LSB first  1: Transfer with MSB first | R/W* <sup>1</sup> |
| b6 to b4 | _      | Reserved                                        | These bits are read as 1. The write value should be 1.                                                                                                                                                                                                                                               | R/W               |
| b7       | BCP2   | Base Clock Pulse 2                              | Selects the number of base clock cycles in combination with the SMR.BCP[1:0] bits.  Table 23.9 lists the combinations of the SCMR.BCP2 bit and SMR.BCP[1:0] bits.                                                                                                                                    | R/W*1             |

Note 1. Writable only when TE in SCR = 0 and RE in SCR = 0 (both serial transmission and reception are disabled).

#### **SMIF Bit (Smart Card Interface Mode Select)**

When this bit is set to 1, smart card interface mode is selected.

When this bit is set to 0, non-smart card interface mode, i.e., asynchronous mode (including multi-processor mode), clock synchronous mode, simple SPI mode, or simple I<sup>2</sup>C mode is selected.

#### SINV Bit (Transmitted/Received Data Invert)

Inverts the transmit/receive data logic level. This bit does not affect the logic level of the parity bit. To invert the parity bit, invert the PM bit in the SMR register.

### **BCP2 Bit (Base Clock Pulse 2)**

Selects the number of base clock cycles in a 1-bit data transfer time in smart card interface mode. Set this bit in combination with the SMR.BCP[1:0] bits.

Table 23.9 Combinations of the SCMR.BCP2 Bit and SMR.BCP[1:0] Bits

| SCMR.BCP2 Bit | SMR.BCP[1 | 1:0] Bits | Number of Base Clock Cycles for 1-Bit Transfer Period |  |  |  |
|---------------|-----------|-----------|-------------------------------------------------------|--|--|--|
| 0             | 0         | 0         | 93 clock cycles (S = 93)*1                            |  |  |  |
| 0             | 0         | 1         | 128 clock cycles (S = 128)*1                          |  |  |  |
| 0             | 1         | 0         | 186 clock cycles (S = 186)*1                          |  |  |  |
| 0             | 1         | 1         | 512 clock cycles (S = 512)*1                          |  |  |  |
| 1             | 0         | 0         | 32 clock cycles (S = 32)*1 (Initial Value)            |  |  |  |
| 1             | 0         | 1         | 64 clock cycles (S = 64)*1                            |  |  |  |
| 1             | 1         | 0         | 372 clock cycles (S = 372)*1                          |  |  |  |
| 1             | 1         | 1         | 256 clock cycles (S = 256)*1                          |  |  |  |

Note 1. S is the value of S in BRR (refer to section 23.2.9, Bit Rate Register (BRR)).

# 23.2.9 Bit Rate Register (BRR)

Address(es): SCI1.BRR 0008 A021h, SCI5.BRR 0008 A0A1h, SCI12.BRR 0008 B301h



The BRR register is an 8-bit register that adjusts the bit rate.

As each SCI channel has independent baud rate generator control, different bit rates can be set for each. Table 23.10 shows the relationship between the setting (N) in the BRR register and the bit rate (B) for normal asynchronous mode, multi-processor transfer, clock synchronous mode, smart card interface mode, simple SPI mode, and simple I<sup>2</sup>C mode. The BRR register is writable only when the TE and RE bits in the SCR register are 0.

Table 23.10 Relationship between N Setting in BRR and Bit Rate B

| Mode                                  | SEMR.ABCS Bit   | BRR Setting                                                     | Error                                                                                                |  |  |  |
|---------------------------------------|-----------------|-----------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--|--|--|
| Asynchronous,                         | 0               | $N = \frac{- PCLK \times 10^6}{64 \times 2^{2n-1} \times B} -1$ | Error (%) = { $\frac{PCLK \times 10^{6}}{B \times 64 \times 2^{2n-1} \times (N+1)} -1 \} \times 100$ |  |  |  |
| multi-processor<br>transfer           | 1               | $N = \frac{PCLK \times 10^{6}}{32 \times 2^{2n-1} \times B} -1$ | Error (%) = { $\frac{PCLK \times 10^{6}}{B \times 32 \times 2^{2n-1} \times (N+1)} -1 \} \times 100$ |  |  |  |
| Clock synchron                        | ous, simple SPI | $N = \frac{PCLK \times 10^{6}}{8 \times 2^{2n-1} \times B} -1$  |                                                                                                      |  |  |  |
| Smart card interface                  |                 | $N = \frac{PCLK \times 10^6}{S \times 2^{2n+1} \times B} -1$    | Error (%) = { $\frac{PCLK \times 10^{6}}{B \times S \times 2^{2n+1} \times (N+1)} -1 \} \times 100$  |  |  |  |
| Simple I <sup>2</sup> C* <sup>1</sup> |                 | $N = \frac{- PCLK \times 10^6}{64 \times 2^{2n-1} \times B} -1$ |                                                                                                      |  |  |  |

B: Bit rate (bps)

N: BRR setting for on-chip baud rate generator (0  $\leq$  N  $\leq$  255)

PCLK: Operating frequency (MHz)

n and S: Determined by the settings of the SMR and SCMR registers as listed in the table below.

Note 1. Adjust the bit rate so that the widths at high and low level of the SCL output in simple I<sup>2</sup>C mode satisfy the I<sup>2</sup>C standard.

Table 23.11 Calculating Widths at High and Low Level for SCL

| Mode             | SCL                                 | Formula (Result in Seconds)                                                   |
|------------------|-------------------------------------|-------------------------------------------------------------------------------|
| I <sup>2</sup> C | Width at high level (minimum value) | $(N+1) \times 4 \times 2^{2n-1} \times 7 \times \frac{1}{PCLK \times 10^6}$   |
|                  | Width at low level (minimum value)  | $(N+1)\times 4\times 2^{2n-1}\times 8\times \frac{1}{\text{PCLK}\times 10^6}$ |

Table 23.12 Clock Source Settings

| SMR.CKS[1:0] Bit Setting | Clock Source | n |
|--------------------------|--------------|---|
| 0 0                      | PCLK         | 0 |
| 0 1                      | PCLK/4       | 1 |
| 10                       | PCLK/16      | 2 |
| 1 1                      | PCLK/64      | 3 |

Table 23.13 Base Clock Settings in Smart Card Interface Mode

| SCMR.BCP2 Bit Setting | SMR.BCP[1:0] Bit Setting | Base Clock Cycles for 1-bit Period | S   |
|-----------------------|--------------------------|------------------------------------|-----|
| 0                     | 0 0                      | 93 clock cycles                    | 93  |
| 0                     | 0 1                      | 128 clock cycles                   | 128 |
| 0                     | 1 0                      | 186 clock cycles                   | 186 |
| 0                     | 11                       | 512 clock cycles                   | 512 |
| 1                     | 0 0                      | 32 clock cycles                    | 32  |
| 1                     | 0 1                      | 64 clock cycles                    | 64  |
| 1                     | 1 0                      | 372 clock cycles                   | 372 |
| 1                     | 11                       | 256 clock cycles                   | 256 |

Table 23.14 lists examples of N settings in BRR in normal asynchronous mode. Table 23.15 lists the maximum bit rate settable for each operating frequency. Examples of BRR (N) settings in clock synchronous mode and simple SPI mode are listed in Table 23.18. Examples of BRR (N) settings in smart card interface mode are listed in Table 23.20. Examples of BRR (N) settings in simple I<sup>2</sup>C mode are listed in Table 23.22. In smart card interface mode, the number of base clock cycles S in a 1-bit data transfer time can be selected. For details, refer to section 23.6.4, Receive Data Sampling Timing and Reception Margin. Table 23.16 and Table 23.19 list the maximum bit rates with external clock input.

When either the asynchronous mode base clock select bit (ABCS) in the serial extended mode register (SEMR) is set to 1 in asynchronous mode, the bit rate becomes twice that listed in Table 23.14.

Table 23.14 Examples of BRR Settings for Various Bit Rates (Asynchronous Mode)

|          |   | Operating Frequency PCLK (MHz) |           |   |        |           |   |     |           |    |     |           |        |     |           |
|----------|---|--------------------------------|-----------|---|--------|-----------|---|-----|-----------|----|-----|-----------|--------|-----|-----------|
| Bit Rate |   | 8                              | 3         |   | 9.8304 |           |   | 10  |           | 12 |     |           | 12.288 |     |           |
| (bps)    | n | N                              | Error (%) | n | N      | Error (%) | n | N   | Error (%) | n  | N   | Error (%) | n      | N   | Error (%) |
| 110      | 2 | 141                            | 0.03      | 2 | 174    | -0.26     | 2 | 177 | -0.25     | 2  | 212 | 0.03      | 2      | 217 | 0.08      |
| 150      | 2 | 103                            | 0.16      | 2 | 127    | 0.00      | 2 | 129 | 0.16      | 2  | 155 | 0.16      | 2      | 159 | 0.00      |
| 300      | 1 | 207                            | 0.16      | 1 | 255    | 0.00      | 2 | 64  | 0.16      | 2  | 77  | 0.16      | 2      | 79  | 0.00      |
| 600      | 1 | 103                            | 0.16      | 1 | 127    | 0.00      | 1 | 129 | 0.16      | 1  | 155 | 0.16      | 1      | 159 | 0.00      |
| 1200     | 0 | 207                            | 0.16      | 0 | 255    | 0.00      | 1 | 64  | 0.16      | 1  | 77  | 0.16      | 1      | 79  | 0.00      |
| 2400     | 0 | 103                            | 0.16      | 0 | 127    | 0.00      | 0 | 129 | 0.16      | 0  | 155 | 0.16      | 0      | 159 | 0.00      |
| 4800     | 0 | 51                             | 0.16      | 0 | 63     | 0.00      | 0 | 64  | 0.16      | 0  | 77  | 0.16      | 0      | 79  | 0.00      |
| 9600     | 0 | 25                             | 0.16      | 0 | 31     | 0.00      | 0 | 32  | -1.36     | 0  | 38  | 0.16      | 0      | 39  | 0.00      |
| 19200    | 0 | 12                             | 0.16      | 0 | 15     | 0.00      | 0 | 15  | 1.73      | 0  | 19  | -2.34     | 0      | 19  | 0.00      |
| 31250    | 0 | 7                              | 0.00      | 0 | 9      | -1.70     | 0 | 9   | 0.00      | 0  | 11  | 0.00      | 0      | 11  | 2.40      |
| 38400    | _ | _                              | _         | 0 | 7      | 0.00      | 0 | 7   | 1.73      | 0  | 9   | -2.34     | 0      | 9   | 0.00      |

|          |   | Operating Frequency PCLK (MHz) |           |   |     |           |   |         |           |    |     |           |         |     |           |
|----------|---|--------------------------------|-----------|---|-----|-----------|---|---------|-----------|----|-----|-----------|---------|-----|-----------|
| Bit Rate |   | 1                              | 4         |   | 1   | 6         |   | 17.2032 |           | 18 |     |           | 19.6608 |     |           |
| (bps)    | n | N                              | Error (%) | n | N   | Error (%) | n | N       | Error (%) | n  | N   | Error (%) | n       | N   | Error (%) |
| 110      | 2 | 248                            | -0.17     | 3 | 70  | 0.03      | 3 | 75      | 0.48      | 3  | 79  | -0.12     | 3       | 86  | 0.31      |
| 150      | 2 | 181                            | 0.16      | 2 | 207 | 0.16      | 2 | 223     | 0.00      | 2  | 233 | 0.16      | 2       | 255 | 0.00      |
| 300      | 2 | 90                             | 0.16      | 2 | 103 | 0.16      | 2 | 111     | 0.00      | 2  | 116 | 0.16      | 2       | 127 | 0.00      |
| 600      | 1 | 181                            | 0.16      | 1 | 207 | 0.16      | 1 | 223     | 0.00      | 1  | 233 | 0.16      | 1       | 255 | 0.00      |
| 1200     | 1 | 90                             | 0.16      | 1 | 103 | 0.16      | 1 | 111     | 0.00      | 1  | 116 | 0.16      | 1       | 127 | 0.00      |
| 2400     | 0 | 181                            | 0.16      | 0 | 207 | 0.16      | 0 | 223     | 0.00      | 0  | 233 | 0.16      | 0       | 255 | 0.00      |
| 4800     | 0 | 90                             | 0.16      | 0 | 103 | 0.16      | 0 | 111     | 0.00      | 0  | 116 | 0.16      | 0       | 127 | 0.00      |
| 9600     | 0 | 45                             | -0.93     | 0 | 51  | 0.16      | 0 | 55      | 0.00      | 0  | 58  | -0.69     | 0       | 63  | 0.00      |
| 19200    | 0 | 22                             | -0.93     | 0 | 25  | 0.16      | 0 | 27      | 0.00      | 0  | 28  | 1.02      | 0       | 31  | 0.00      |
| 31250    | 0 | 13                             | 0.00      | 0 | 15  | 0.00      | 0 | 16      | 1.20      | 0  | 17  | 0.00      | 0       | 19  | -1.70     |
| 38400    |   | _                              | _         | 0 | 12  | 0.16      | 0 | 13      | 0.00      | 0  | 14  | -2.34     | 0       | 15  | 0.00      |

|          |   | Operating Frequency PCLK (MHz) |           |   |     |           |    |     |           |  |  |
|----------|---|--------------------------------|-----------|---|-----|-----------|----|-----|-----------|--|--|
| Bit Rate |   | 2                              | 0         |   | 2   | 5         | 30 |     |           |  |  |
| (bps)    | n | N                              | Error (%) | n | N   | Error (%) | n  | N   | Error (%) |  |  |
| 110      | 3 | 88                             | -0.25     | 3 | 110 | -0.02     | 3  | 132 | 0.13      |  |  |
| 150      | 3 | 64                             | 0.16      | 3 | 80  | 0.47      | 3  | 97  | -0.35     |  |  |
| 300      | 2 | 129                            | 0.16      | 2 | 162 | -0.15     | 2  | 194 | 0.16      |  |  |
| 600      | 2 | 64                             | 0.16      | 2 | 80  | 0.47      | 2  | 97  | -0.35     |  |  |
| 1200     | 1 | 129                            | 0.16      | 1 | 162 | -0.15     | 1  | 194 | 0.16      |  |  |
| 2400     | 1 | 64                             | 0.16      | 1 | 80  | 0.47      | 1  | 97  | -0.35     |  |  |
| 4800     | 0 | 129                            | 0.16      | 0 | 162 | -0.15     | 0  | 194 | 0.16      |  |  |
| 9600     | 0 | 64                             | 0.16      | 0 | 80  | 0.47      | 0  | 97  | -0.35     |  |  |
| 19200    | 0 | 32                             | -1.36     | 0 | 40  | -0.76     | 0  | 48  | -0.35     |  |  |
| 31250    | 0 | 19                             | 0.00      | 0 | 24  | 0.00      | 0  | 29  | 0         |  |  |
| 38400    | 0 | 15                             | 1.73      | 0 | 19  | 1.73      | 0  | 23  | 1.73      |  |  |

Note: This is an example when the ABCS bit is 0. When the ABCS bit is set to 1, the bit rate doubles.

Table 23.15 Maximum Bit Rate for Each Operating Frequency (Asynchronous Mode)

| PCLK   |   | _ | Maximum Bit Rate | PCLK    |   | Maximum Bit Rate |        |
|--------|---|---|------------------|---------|---|------------------|--------|
| (MHz)  | n | N | (bps)            | (MHz)   | n | N                | (bps)  |
| 8      | 0 | 0 | 250000           | 17.2032 | 0 | 0                | 537600 |
| 9.8304 | 0 | 0 | 307200           | 18      | 0 | 0                | 562500 |
| 10     | 0 | 0 | 312500           | 19.6608 | 0 | 0                | 614400 |
| 12     | 0 | 0 | 375000           | 20      | 0 | 0                | 625000 |
| 12.288 | 0 | 0 | 384000           | 25      | 0 | 0                | 718250 |
| 14     | 0 | 0 | 437500           | 30      | 0 | 0                | 937500 |
| 16     | 0 | 0 | 500000           |         |   |                  |        |

Note: When the ABCS bit in the SEMR register is set to 1, the bit rate is two times.

Table 23.16 Maximum Bit Rate with External Clock Input (Asynchronous Mode)

|            |                            | Maximum Bit Rate (bps) |                   |  |  |  |  |  |
|------------|----------------------------|------------------------|-------------------|--|--|--|--|--|
| PCLK (MHz) | External Input Clock (MHz) | SEMR.ABCS Bit = 0      | SEMR.ABCS Bit = 1 |  |  |  |  |  |
| 8          | 2.0000                     | 125000                 | 250000            |  |  |  |  |  |
| 9.8304     | 2.4576                     | 153600                 | 307200            |  |  |  |  |  |
| 10         | 2.5000                     | 156250                 | 312500            |  |  |  |  |  |
| 12         | 3.0000                     | 187500                 | 375000            |  |  |  |  |  |
| 12.288     | 3.0720                     | 192000                 | 384000            |  |  |  |  |  |
| 14         | 3.5000                     | 218750                 | 437500            |  |  |  |  |  |
| 16         | 4.0000                     | 250000                 | 500000            |  |  |  |  |  |
| 17.2032    | 4.3008                     | 268800                 | 537600            |  |  |  |  |  |
| 18         | 4.5000                     | 281250                 | 562500            |  |  |  |  |  |
| 19.6608    | 4.9152                     | 307200                 | 614400            |  |  |  |  |  |
| 20         | 5.0000                     | 312500                 | 625000            |  |  |  |  |  |
| 25         | 6.2500                     | 390625                 | 781250            |  |  |  |  |  |
| 30         | 7.5000                     | 468750                 | 937500            |  |  |  |  |  |

Table 23.17 Maximum Bit Rate with MTU Clock Input (Asynchronous Mode)

|            |                 | Maximum Bit Rate (bp | os)               |
|------------|-----------------|----------------------|-------------------|
| PCLK (MHz) | MTU Clock (MHz) | SEMR.ABCS Bit = 0    | SEMR.ABCS Bit = 1 |
| 8          | 4               | 250000               | 500000            |
| 9.8304     | 4.9152          | 307200               | 614400            |
| 10         | 5               | 312500               | 625000            |
| 12         | 6               | 375000               | 750000            |
| 12.288     | 6.144           | 384000               | 768000            |
| 14         | 7               | 437500               | 875000            |
| 16         | 8               | 500000               | 1000000           |
| 17.2032    | 8.6016          | 537600               | 1075200           |
| 18         | 9               | 562500               | 1125000           |
| 19.6608    | 9.8304          | 614400               | 1228800           |
| 20         | 10              | 625000               | 1250000           |
| 25         | 12.5            | 781250               | 1562500           |
| 30         | 15              | 937500               | 1875000           |

Table 23.18 BRR Settings for Various Bit Rates (Clock Synchronous Mode, Simple SPI Mode)

|                | Operating Frequency PCLK (MHz) |     |   |          |   |     |   |            |          |          |          |     |  |
|----------------|--------------------------------|-----|---|----------|---|-----|---|------------|----------|----------|----------|-----|--|
|                | 8                              |     |   | 10       |   | 16  |   | 20         |          | 25       |          | 30  |  |
| Bit Rate (bps) | n                              | N   | n | N        | n | N   | n | N          | n        | N        | n        | N   |  |
| 110            |                                |     |   |          |   |     |   |            |          |          |          |     |  |
| 250            | 3                              | 124 | _ | _        | 3 | 249 |   |            |          |          |          |     |  |
| 500            | 2                              | 249 | _ | _        | 3 | 124 | _ | _          |          |          | 3        | 233 |  |
| 1 k            | 2                              | 124 | _ | <u> </u> | 2 | 249 | _ | <b> </b> - | 3        | 97       | 3        | 116 |  |
| 2.5 k          | 1                              | 199 | 1 | 249      | 2 | 99  | 2 | 124        | 2        | 155      | 2        | 187 |  |
| 5 k            | 1                              | 99  | 1 | 124      | 1 | 199 | 1 | 249        | 2        | 77       | 2        | 93  |  |
| 10 k           | 0                              | 199 | 0 | 249      | 1 | 99  | 1 | 124        | 1        | 155      | 1        | 187 |  |
| 25 k           | 0                              | 79  | 0 | 99       | 0 | 159 | 0 | 199        | 0        | 249      | 1        | 74  |  |
| 50 k           | 0                              | 39  | 0 | 49       | 0 | 79  | 0 | 99         | 0        | 124      | 0        | 149 |  |
| 100 k          | 0                              | 19  | 0 | 24       | 0 | 39  | 0 | 49         | 0        | 62       | 0        | 74  |  |
| 250 k          | 0                              | 7   | 0 | 9        | 0 | 15  | 0 | 19         | 0        | 24       | 0        | 29  |  |
| 500 k          | 0                              | 3   | 0 | 4        | 0 | 7   | 0 | 9          | _        | <b>—</b> | 0        | 14  |  |
| 1 M            | 0                              | 1   |   |          | 0 | 3   | 0 | 4          | <u> </u> | _        | _        | _   |  |
| 2 M            | 0                              | 0*1 |   |          | 0 | 1   |   |            | _        | <b>—</b> | _        | _   |  |
| 2.5 M          |                                |     | 0 | 0*1      |   |     | 0 | 1          |          |          | 0        | 2   |  |
| 4 M            |                                |     |   |          | 0 | 0*1 |   |            |          |          | <b>—</b> | _   |  |
| 5 M            |                                |     |   |          |   |     | 0 | 0*1        |          |          |          |     |  |
| 6.25 M         |                                |     |   |          |   |     |   |            | 0        | 0*1      |          |     |  |
| 7.5 M          |                                |     |   |          |   |     |   |            |          |          | 0        | 0*1 |  |

Space: Setting prohibited.

Note 1. Continuous transmission or reception is not possible. After transmitting/receiving one frame of data, there is an interval of a 1-bit period before starting transmitting/receiving the next frame of data. The output of the synchronization clock is stopped for a 1-bit period. For this reason, it takes 9 bits worth of time to transfer one frame (8 bits) of data, and the average transfer rate is 8/9 times the bit rate.

Table 23.19 Maximum Bit Rate with External Clock Input (Clock Synchronous Mode, Simple SPI Mode)

| PCLK (MHz) | External Input Clock (MHz) | Maximum Bit Rate (Mbps) |
|------------|----------------------------|-------------------------|
| 8          | 1.3333                     | 1.3333                  |
| 10         | 1.6667                     | 1.6667                  |
| 12         | 2.0000                     | 2.0000                  |
| 14         | 2.3333                     | 2.3333                  |
| 16         | 2.6667                     | 2.6667                  |
| 18         | 3.0000                     | 3.0000                  |
| 20         | 3.3333                     | 3.3333                  |
| 25         | 4.1667                     | 4.1667                  |
| 30         | 5.0000                     | 5.0000                  |

<sup>—:</sup> Can be set, but an error will occur.

Table 23.20 BRR Settings for Various Bit Rates (Smart Card Interface Mode, n = 0, S = 372)

| Bit Rate (bps) | PCLK (MHz) | n | N | Error (%) |
|----------------|------------|---|---|-----------|
| 9600           | 7.1424     | 0 | 0 | 0.00      |
|                | 10.00      | 0 | 1 | 30        |
|                | 10.7136    | 0 | 1 | 25        |
|                | 13.00      | 0 | 1 | 8.99      |
|                | 14.2848    | 0 | 1 | 0.00      |
|                | 16.00      | 0 | 1 | 12.01     |
|                | 18.00      | 0 | 2 | 15.99     |
|                | 20.00      | 0 | 2 | 6.66      |
|                | 25.00      | 0 | 3 | 12.49     |
|                | 30.00      | 0 | 3 | 5.01      |

Table 23.21 Maximum Bit Rate for Each Operating Frequency (Smart Card Interface Mode, S = 32)

| PCLK (MHz) | Maximum Bit Rate (bps) | n | N |  |
|------------|------------------------|---|---|--|
| 10.00      | 156250                 | 0 | 0 |  |
| 10.7136    | 167400                 | 0 | 0 |  |
| 13.00      | 203125                 | 0 | 0 |  |
| 16.00      | 250000                 | 0 | 0 |  |
| 18.00      | 281250                 | 0 | 0 |  |
| 20.00      | 312500                 | 0 | 0 |  |
| 25.00      | 390625                 | 0 | 0 |  |
| 30.00      | 468750                 | 0 | 0 |  |

Table 23.22 BRR Settings for Various Bit Rates (Simple I<sup>2</sup>C Mode)

|          |   | Operating Frequency PCLK (MHz) |           |    |    |           |   |    |           |   |    |           |   |    |           |  |
|----------|---|--------------------------------|-----------|----|----|-----------|---|----|-----------|---|----|-----------|---|----|-----------|--|
| Bit Rate |   | ;                              | 8         | 10 |    |           |   | 16 |           |   | 20 |           |   | 25 |           |  |
| (bps)    | n | N                              | Error (%) | n  | N  | Error (%) | n | N  | Error (%) | n | N  | Error (%) | n | N  | Error (%) |  |
| 10 k     | 0 | 24                             | 0.0       | 0  | 31 | -2.3      | 1 | 12 | -3.8      | 1 | 15 | -2.3      | 1 | 19 | -2.3      |  |
| 25 k     | 0 | 9                              | 0.0       | 0  | 12 | -3.8      | 1 | 4  | 0.0       | 1 | 6  | -10.7     | 1 | 7  | -2.3      |  |
| 50 k     | 0 | 4                              | 0.0       | 0  | 6  | -10.7     | 1 | 2  | -16.7     | 1 | 3  | -21.9     | 1 | 3  | -2.3      |  |
| 100 k    | 0 | 2                              | -16.7     | 0  | 3  | -21.9     | 0 | 4  | 0.0       | 0 | 6  | -10.7     | 1 | 1  | -2.3      |  |
| 250 k    | 0 | 0                              | 0.0       | 0  | 1  | -37.5     | 0 | 1  | 0.0       | 0 | 2  | -16.7     | 0 | 3  | -21.9     |  |
| 350 k    |   |                                |           |    |    |           |   |    |           | 0 | 1  | -10.7     | 0 | 2  | -25.6     |  |

|          | Operating Frequency<br>PCLK (MHz) |    |           |  |  |  |  |  |
|----------|-----------------------------------|----|-----------|--|--|--|--|--|
| Bit Rate | 30                                |    |           |  |  |  |  |  |
| (bps)    | n                                 | N  | Error (%) |  |  |  |  |  |
| 10 k     | 1                                 | 23 | -2.3      |  |  |  |  |  |
| 25 k     | 1                                 | 9  | -6.3      |  |  |  |  |  |
| 50 k     | 1                                 | 4  | -6.3      |  |  |  |  |  |
| 100 k    | 1                                 | 2  | -21.9     |  |  |  |  |  |
| 250 k    | 0                                 | 3  | -6.3      |  |  |  |  |  |
| 350 k    | 0                                 | 2  | -10.7     |  |  |  |  |  |

Table 23.23 Minimum Widths at High and Low Level for SCL at Various Bit Rates (Simple I<sup>2</sup>C Mode)

|                   |   |    |                                                  |   |    | Operating Frequ                                  | ency | PCLK | (MHz)                                            |   |    |                                                  |  |
|-------------------|---|----|--------------------------------------------------|---|----|--------------------------------------------------|------|------|--------------------------------------------------|---|----|--------------------------------------------------|--|
|                   |   |    | 8                                                |   |    | 10                                               |      | 16   |                                                  |   | 20 |                                                  |  |
| Bit Rate<br>(bps) | n | N  | Min. Widths at<br>High/Low Level<br>for SCL (µs) | n | N  | Min. Widths at<br>High/Low Level<br>for SCL (μs) | n    | N    | Min. Widths at<br>High/Low Level<br>for SCL (μs) | n | N  | Min. Widths at<br>High/Low Level<br>for SCL (μs) |  |
| 10 k              | 0 | 24 | 43.75/50.00                                      | 0 | 31 | 44.80/51.20                                      | 1    | 12   | 45.50/52.00                                      | 1 | 15 | 44.80/51.20                                      |  |
| 25 k              | 0 | 9  | 17.50/20.00                                      | 0 | 12 | 18.20/20.80                                      | 1    | 4    | 17.50/20.00                                      | 1 | 6  | 19.60/22.40                                      |  |
| 50 k              | 0 | 4  | 8.75/10.00                                       | 0 | 6  | 9.80/11.20                                       | 1    | 2    | 10.50/12.00                                      | 1 | 3  | 11.20/12.80                                      |  |
| 100 k             | 0 | 2  | 5.25/6.00                                        | 0 | 3  | 5.60/6.40                                        | 0    | 4    | 4.37/5.00                                        | 0 | 6  | 4.90/5.60                                        |  |
| 250 k             | 0 | 0  | 1.75/2.00                                        | 0 | 1  | 2.80/3.20                                        | 0    | 1    | 1.75/2.00                                        | 0 | 2  | 2.10/2.40                                        |  |
| 350 k             |   |    |                                                  |   |    |                                                  |      |      |                                                  | 0 | 1  | 1.40/1.60                                        |  |

|                   |   | Operating Frequency PCLK (MHz) |                                                  |    |    |                                                  |  |  |  |  |  |
|-------------------|---|--------------------------------|--------------------------------------------------|----|----|--------------------------------------------------|--|--|--|--|--|
|                   |   |                                | 25                                               | 30 |    |                                                  |  |  |  |  |  |
| Bit Rate<br>(bps) | n | N                              | Min. Widths at<br>High/Low Level<br>for SCL (µs) | n  | N  | Min. Widths at<br>High/Low Level<br>for SCL (µs) |  |  |  |  |  |
| 10 k              | 1 | 19                             | 44.80/51.20                                      | 1  | 23 | 44.80/51.20                                      |  |  |  |  |  |
| 25 k              | 1 | 7                              | 17.92/20.48                                      | 1  | 9  | 18.66/21.33                                      |  |  |  |  |  |
| 50 k              | 1 | 3                              | 8.96/10.24                                       | 1  | 4  | 9.33/10.66                                       |  |  |  |  |  |
| 100 k             | 1 | 1                              | 4.48/5.12                                        | 1  | 2  | 5.60/6.40                                        |  |  |  |  |  |
| 250 k             | 0 | 3                              | 2.24/2.56                                        | 0  | 3  | 1.86/2.13                                        |  |  |  |  |  |
| 350 k             | 0 | 2                              | 1.68/1.92                                        | 0  | 2  | 1.40/1.60                                        |  |  |  |  |  |

# 23.2.10 Serial Extended Mode Register (SEMR)

Address(es): SCI1.SEMR 0008 A027h, SCI5.SEMR 0008 A0A7h, SCI12.SEMR 0008 B307h



| Bit      | Symbol  | Bit Name                                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W   |
|----------|---------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| b0       | ACS0    | Asynchronous Mode<br>Clock Source Select        | (Valid only in asynchronous mode) 0: External clock input 1: Logical AND of two compare matches output from MTU                                                                                                                                                                                                                                                                                                               | R/W*1 |
| b3 to b1 | _       | Reserved                                        | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                                                                        | R/W   |
| b4       | ABCS    | Asynchronous Mode<br>Base Clock Select          | (Valid only in asynchronous mode) 0: Selects 16 base clock cycles for 1-bit period. 1: Selects 8 base clock cycles for 1-bit period.                                                                                                                                                                                                                                                                                          | R/W*1 |
| b5       | NFEN    | Digital Noise Filter<br>Function Enable         | (In asynchronous mode) 0: Noise cancellation function for the RXDn input signal is disabled. 1: Noise cancellation function for the RXDn input signal is enabled. (in simple I <sup>2</sup> C mode) 0: Noise cancellation function for the SSCLn and SSDAn input signals is disabled. 1: Noise cancellation function for the SSCLn and SSDAn input signals is enabled. The NFEN bit should be 0 in any mode other than above. | R/W*1 |
| b6       | _       | Reserved                                        | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                                                                           | R/W   |
| b7       | RXDESEL | Asynchronous Start Bit<br>Edge Detection Select | (Valid only in asynchronous mode) 0: The low level on the RXDn pin is detected as the start bit. 1: A falling edge on the RXDn pin is detected as the start bit.                                                                                                                                                                                                                                                              | R/W*1 |

Note 1. Writable only when TE in SCR = 0 and RE in SCR = 0 (both serial transmission and reception are disabled).

The SEMR register is used to select a clock source for 1-bit period in asynchronous mode or a detection method of the start bit.

#### **ACS0 Bit (Asynchronous Mode Clock Source Select)**

Selects the clock source in the asynchronous mode.

The ACS0 bit is valid in asynchronous mode (SMR.CM bit = 0) and when an external clock input is selected (SCR.CKE[1:0] bits = 10b or 11b). This bit is used to select an external clock input or the logical AND of compare matches output from the internal MTU.

Set the ACS0 bit to 0 in other than asynchronous mode.

The MTIOC1A and MTIOC2A output of the MTU can be set as the serial transfer base clock. Refer to Table 23.24 for details.

Table 23.24 Correspondence between SCI Channels and Compare Match Outputs

| SCI   | MTU        | Compare Match Output |
|-------|------------|----------------------|
| SCI1  | MTU1, MTU2 | MTIOC1A, MTIOC2A     |
| SCI5  | MTU1, MTU2 | MTIOC1A, MTIOC2A     |
| SCI12 | MTU1, MTU2 | MTIOC1A, MTIOC2A     |

Figure 23.3 shows a setting example of when MTIOC1A and MTIOC2A in the MTU are selected for output.





Figure 23.3 Example of Average Transfer Rate Setting When MTU Clock is Input

#### NFEN Bit (Digital Noise Filter Function Enable)

This bit enables or disables the digital noise filter function.

When the function is enabled, noise cancellation is applied to the RXDn input signal in asynchronous mode, and noise cancellation is applied to the SSDAn and SSCLn input signals in simple I<sup>2</sup>C mode.

In any mode other than above, set the NFEN bit to 0 to disable the digital noise filter function.

When the function is disabled, input signals are transferred as is, as internal signals.

#### **RXDESEL Bit (Asynchronous Start Bit Edge Detection Select)**

Selects the detection method of the start bit for reception in asynchronous mode. When a break occurs, data receiving operation depends on the settings of this bit. Set this bit to 1 when reception should be stopped while a break occurs or when reception should be started without retaining the RXDn pin input at high level for the period of one data frame or longer after completion of the break.

Set this bit to 0 in modes other than asynchronous mode.

# 23.2.11 Noise Filter Setting Register (SNFR)

Address(es): SCI1.SNFR 0008 A028h, SCI5.SNFR 0008 A0A8h, SCI12.SNFR 0008 B308h



| Bit      | Symbol    | Bit Name                  | Description                                                                        | R/W   |
|----------|-----------|---------------------------|------------------------------------------------------------------------------------|-------|
| b2 to b0 | NFCS[2:0] | Noise Filter Clock Select | In asynchronous mode, the standard setting for the base clock is as follows.       | R/W*1 |
|          |           |                           | 0 0 0: The clock signal divided by 1 is used with the noise filter.                |       |
|          |           |                           | In simple I <sup>2</sup> C mode, the standard settings for the clock source of the |       |
|          |           |                           | on-chip baud rate generator selected by the SMR.CKS[1:0] bits are given below.     |       |
|          |           |                           | b2 b0<br>0 0 1: The clock signal divided by 1 is used with the noise filter.       |       |
|          |           |                           | 0 1 0: The clock signal divided by 1 is used with the noise filter.                |       |
|          |           |                           | 0 1 1: The clock signal divided by 4 is used with the noise filter.                |       |
|          |           |                           | 1 0 0: The clock signal divided by 8 is used with the noise filter.                |       |
|          |           |                           | Settings other than above are prohibited.                                          |       |
| b7 to b3 | _         | Reserved                  | These bits are read as 0. The write value should be 0.                             | R/W   |

Note 1. Writing to these bits is only possible when the RE and TE bits in the SCR are 0 (serial reception and transmission disabled).

#### NFCS[2:0] Bits (Noise Filter Clock Select)

These bits select the sampling clock for the digital noise filter. To use the noise filter in asynchronous mode, set these bits to 000b. In simple  $I^2C$  mode, set the bits to a value in the range from 001b to 100b.

# 23.2.12 I<sup>2</sup>C Mode Register 1 (SIMR1)

Address(es): SCI1.SIMR1 0008 A029h, SCI5.SIMR1 0008 A0A9h, SCI12.SIMR1 0008 B309h



| Bit      | Symbol     | Bit Name                            | Description                                                                                                                                                                                                                                                                                          | R/W               |
|----------|------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| b0       | IICM       | Simple I <sup>2</sup> C Mode Select | SMIF IICM 0 0: Asynchronous mode, Multi-processor mode, Clock synchronous mode (in asynchronous mode, synchronous, or simple SPI mode) 0 1: Simple I <sup>2</sup> C mode 1 0: Smart card interface mode 1 1: Setting prohibited.                                                                     | R/W* <sup>1</sup> |
| b2, b1   | _          | Reserved                            | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                                                               | R/W               |
| b7 to b3 | IICDL[4:0] | SSDA Output Delay Select            | (Cycles below are of the clock signal from the on-chip baud rate generator.)  b7  b3  0 0 0 0 0: No output delay 0 0 0 0 1: 0 to 1 cycle 0 0 0 1 0: 1 to 2 cycles 0 0 0 1 1: 2 to 3 cycles 0 0 1 0 0: 3 to 4 cycles 0 0 1 0 1: 4 to 5 cycles : 1 1 1 1 0: 29 to 30 cycles 1 1 1 1 1: 30 to 31 cycles | R/W* <sup>1</sup> |

Note 1. Writing to these bits is only possible when the RE and TE bits in the SCR are 0 (both serial transmission and reception are disabled).

SIMR1 is used to select simple I<sup>2</sup>C mode and the number of delay stages for the SSDA output.

#### IICM Bit (Simple I<sup>2</sup>C Mode Select)

In conjunction with the SMIF bit in the SCMR register, this bit selects the operating mode.

### IICDL[4:0] Bits (SSDA Output Delay Select)

These bits are used to set a delay for output on the SSDAn pin relative to the falling edge of the output on the SSCLn pin. The available delay settings range from no delay to 31 cycles, with the clock signal from the on-chip baud rate generator as the base. The signal obtained by frequency-dividing PCLK by the divisor set in the SMR.CKS[1:0] bits is supplied as the clock signal from the on-chip baud rate generator. Set these bits to 00000b unless operation is in simple I<sup>2</sup>C mode. In simple I<sup>2</sup>C mode, set the bits to a value in the range from 00001b to 11111b.

# 23.2.13 I<sup>2</sup>C Mode Register 2 (SIMR2)

Address(es): SCI1.SIMR2 0008 A02Ah, SCI5.SIMR2 0008 A0AAh, SCI12.SIMR2 0008 B30Ah



| Bit      | Symbol  | Bit Name                               | Description                                                                        | R/W   |
|----------|---------|----------------------------------------|------------------------------------------------------------------------------------|-------|
| b0       | IICINTM | I <sup>2</sup> C Interrupt Mode Select | Use ACK/NACK interrupts.     Use reception and transmission interrupts.            | R/W*1 |
| b1       | IICCSC  | Clock Synchronization                  | No synchronization with the clock signal     Synchronization with the clock signal | R/W*1 |
| b4 to b2 | _       | Reserved                               | These bits are read as 0. The write value should be 0.                             | R/W   |
| b5       | IICACKT | ACK Transmission Data                  | 0: ACK transmission 1: NACK transmission and reception of ACK/NACK                 | R/W   |
| b7, b6   | _       | Reserved                               | These bits are read as 0. The write value should be 0.                             | R/W   |

Note 1. Writing to these bits is only possible when the RE and TE bits in the SCR are 0 (serial reception and transmission disabled).

SIMR2 is used to select how reception and transmission are controlled in simple I<sup>2</sup>C mode.

### **IICINTM Bit (I<sup>2</sup>C Interrupt Mode Select)**

This bit selects the sources of interrupt requests in simple I<sup>2</sup>C mode.

### **IICCSC Bit (Clock Synchronization)**

Set the IICCSC bit to 1 if the internally generated SSCLn clock signal is to be synchronized when the SSCLn pin has been placed at the low level in the case of a wait inserted by the other device, etc.

The SSCLn clock signal is not synchronized if the IICCSC bit is 0. The SSCLn clock signal is generated in accord with the rate selected in the BRR regardless of the level being input on the SSCLn pin.

Set the IICCSC bit to 1 except during debugging.

#### **IICACKT Bit (ACK Transmission Data)**

Transmitted data contains ACK bits. Set this bit to 1 when ACK and NACK bits are received.

# 23.2.14 I<sup>2</sup>C Mode Register 3 (SIMR3)

Address(es): SCI1.SIMR3 0008 A02Bh, SCI5.SIMR3 0008 A0ABh, SCI12.SIMR3 0008 B30Bh



| Bit    | Symbol       | Bit Name                                                       | Description                                                                                                                                                                                                                                 | R/W |
|--------|--------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0     | IICSTAREQ    | Start Condition Generation                                     | 0: A start condition is not generated. 1: A start condition is generated.*1, *3, *4, *5                                                                                                                                                     | R/W |
| b1     | IICRSTAREQ   | Restart Condition Generation                                   | 0: A restart condition is not generated. 1: A restart condition is generated. *2, *3, *4, *5                                                                                                                                                | R/W |
| b2     | IICSTPREQ    | Stop Condition Generation                                      | 0: A stop condition is not generated. 1: A stop condition is generated.*2, *3, *4, *5                                                                                                                                                       | R/W |
| b3     | IICSTIF      | Issuing of Start, Restart, or Stop<br>Condition Completed Flag | O: There are no requests for generating conditions or a condition is being generated.  1: A start, restart, or stop condition is completely generated.                                                                                      | R/W |
| b5, b4 | IICSDAS[1:0] | SSDA Output Select                                             | <ul> <li>b5 b4</li> <li>0 0: Serial data output</li> <li>0 1: Generate a start, restart, or stop condition.</li> <li>1 0: Output the low level on the SSDAn pin.</li> <li>1 1: Place the SSDAn pin in the high-impedance state.</li> </ul>  | R/W |
| b7, b6 | IICSCLS[1:0] | SSCL Output Select                                             | <ul> <li>b7 b6</li> <li>0 0: Serial clock output</li> <li>0 1: Generate a start, restart, or stop condition.</li> <li>1 0: Output the low level on the SSCLn pin.</li> <li>1 1: Place the SSCLn pin in the high-impedance state.</li> </ul> | R/W |

- Note 1. Only generate a start condition after checking the bus state and confirming that it is free.
- Note 2. Generate a restart or stop condition after checking the bus state and confirming that it is busy.
- Note 3. Do not set more than one from among the IICSTAREQ, IICRSTAREQ, and IICSTPREQ bits to 1 at a given time.
- Note 4. Execute the generation of a condition after the value of the IICSTIF flag is 0.
- Note 5. Do not write 0 to this bit while it is 1. Generation of a condition is suspended by writing 0 to this bit while it is 1.

SIMR3 is used to control the simple I<sup>2</sup>C mode start and stop conditions, and to hold the SSDAn and SSCLn pins at fixed levels.

#### **IICSTAREQ Bit (Start Condition Generation)**

When a start condition is to be generated, set both the IICSDAS[1:0] and IICSCLS[1:0] bits to 01b as well as setting the IICSTAREQ bit to 1.

[Setting condition]

• Writing 1 to the bit

[Clearing condition]

• Completion of generation of the start condition

#### **IICRSTAREQ Bit (Restart Condition Generation)**

When a restart condition is to be generated, set both the IICSDAS[1:0] and IICSCLS[1:0] bits to 01b as well as setting the IICRSTAREQ bit to 1.

[Setting condition]

• Writing 1 to the bit

[Clearing condition]

• Completion of generation of the restart condition



#### **IICSTPREQ Bit (Stop Condition Generation)**

When a stop condition is to be generated, set both the IICSDAS[1:0] and IICSCLS[1:0] bits to 01b as well as setting the IICSTPREQ bit to 1.

[Setting condition]

• Writing 1 to the bit

[Clearing condition]

• Completion of generation of the stop condition

#### IICSTIF Flag (Issuing of Start, Restart, or Stop Condition Completed Flag)

After generating a condition, this bit indicates that the generation is completed. When using the IICSTAREQ, IICRSTAREQ, or IICSTPREQ bit to cause generation of a condition, do so after setting the IICSTIF flag to 0. When the IICSTIF flag is 1 while an interrupt request is enabled by setting the SCR.TEIE bit, an STI request is output. [Setting condition]

• Completion of the generation of a start, restart, or stop condition (however, in cases where this conflicts with any of the conditions for the flag becoming 0 listed below, the other condition takes precedence)

[Clearing conditions]

- Writing 0 to the bit (confirm that the IICSTIF flag is 0 before doing so)
- Writing 0 to the SIMR1.IICM bit (when operation is not in simple I<sup>2</sup>C mode)
- Writing 0 to the SCR.TE bit

#### IICSDAS[1:0] Bits (SSDA Output Select)

These bits control output from the SSDAn pin.

Set the IICSDAS[1:0] and IICSCLS[1:0] bits to the same value during normal operations.

#### IICSCLS[1:0] Bits (SSCL Output Select)

These bits control output from the SSCLn pin.

Set the IICSCLS[1:0] and IICSDAS[1:0] bits to the same value during normal operations.



# 23.2.15 I<sup>2</sup>C Status Register (SISR)

Address(es): SCI1.SISR 0008 A02Ch, SCI5.SISR 0008 A0ACh, SCI12.SISR 0008 B30Ch



x: Undefined

| Bit    | Symbol  | Bit Name                | Description                                            | R/W   |
|--------|---------|-------------------------|--------------------------------------------------------|-------|
| b0     | IICACKR | ACK Reception Data Flag | 0: ACK received<br>1: NACK received                    | R/W*1 |
| b1     | _       | Reserved                | This bit is read as 0. The write value should be 0.    | R/W   |
| b2     | _       | Reserved                | The read value is undefined.                           | R     |
| b3     | _       | Reserved                | This bit is read as 0. The write value should be 0.    | R/W   |
| b5, b4 | _       | Reserved                | The read value is undefined.                           | R     |
| b7, b6 | _       | Reserved                | These bits are read as 0. The write value should be 0. | R/W   |

Note 1. Only 0 can be written to this bit, to clear the flag.

SISR is used to monitor state in relation to simple I<sup>2</sup>C mode.

### **IICACKR Flag (ACK Reception Data Flag)**

Received ACK and NACK bits can be read from this bit.

The IICACKR flag is updated at the rising of SSCLn clock for the ACK/NACK receiving bit.

# 23.2.16 SPI Mode Register (SPMR)

Address(es): SCI1.SPMR 0008 A02Dh, SCI5.SPMR 0008 A0ADh, SCI12.SPMR 0008 B30Dh



| Bit | Symbol | Bit Name                 | Description                                                                                                                                                                                                        | R/W   |
|-----|--------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| b0  | SSE    | SSn# Pin Function Enable | 0: SSn# pin function is disabled. 1: SSn# pin function is enabled.                                                                                                                                                 | R/W*1 |
| b1  | CTSE   | CTS Enable               | CTS function is disabled (RTS output function is enabled).     CTS function is enabled.                                                                                                                            | R/W*1 |
| b2  | MSS    | Master Slave Select      | <ul><li>0: Transmission is through the TXDn pin and reception is through the RXDn pin (master mode).</li><li>1: Reception is through the TXDn pin and transmission is through the RXDn pin (slave mode).</li></ul> | R/W*1 |
| b3  | _      | Reserved                 | This bit is read as 0. The write value should be 0.                                                                                                                                                                | R/W   |
| b4  | MFF    | Mode Fault Flag          | 0: No mode fault error 1: Mode fault error                                                                                                                                                                         | R/W*2 |
| b5  | _      | Reserved                 | This bit is read as 0. The write value should be 0.                                                                                                                                                                | R/W   |
| b6  | CKPOL  | Clock Polarity Select    | Clock polarity is not inverted.     Clock polarity is inverted.                                                                                                                                                    | R/W*1 |
| b7  | СКРН   | Clock Phase Select       | Clock is not delayed.     Clock is delayed.                                                                                                                                                                        | R/W*1 |

Note 1. Writing to these bits is only possible when the RE and TE bits in the SCR are 0 (both serial transmission and reception are disabled).

SPMR is used to select the extension settings in asynchronous and clock synchronous modes.

#### SSE Bit (SSn# Pin Function Enable)

Set this bit to 1 if the SSn# pin is to be used in control of transmission and reception (in simple SPI mode). Set this bit to 0 in any other mode. Furthermore, even for usage in simple SPI mode, the SSn# pin on the master side is not required to control reception and transmission when master mode (SCR.CKE[1:0] = 00b and MSS = 0) is selected and there is a single master, so the setting for the SSE bit is 0. Do not set both the SSE and CTSE bits to enabled (even if this setting is made, operation is the same as that when these bits are set to 0).

#### CTSE Bit (CTS Enable)

Set this bit to 1 if the SSn# pin is to be used for inputting of the CTS control signal to control of transmission and reception. The RTS signal is output when this bit is set to 0. Set this bit to 0 in smart card interface mode, simple SPI mode, and simple I<sup>2</sup>C mode. Do not set both the CTSE and SSE bits to enabled (even if this setting is made, operation is the same as that when these bits are set to 0).

#### MSS Bit (Master Slave Select)

This bit selects between master and slave operation in simple SPI mode. The functions of the TXDn and RXDn pins are reversed when the MSS bit is set to 1, so that data is received through the TXDn pin and transmitted through the RXDn pin.

Set this bit to 0 in modes other than simple SPI mode.



Note 2. Only 0 can be written to these bits, which clears the flag.

#### MFF Flag (Mode Fault Flag)

This bit indicates mode fault errors.

In a multi-master configuration, determine the mode fault error occurrence by reading the MFF flag. [Setting condition]

• Input on the SSn# pin being at the low level during master operation in simple SPI mode (SSE bit = 1 and MSS bit = 0)

[Clearing condition]

• Writing 0 to the bit after it was read as 1

#### **CKPOL Bit (Clock Polarity Select)**

This bit selects the polarity of the clock signal output through the SCKn pin. Refer to Figure 23.55 for details. Set the bit to 0 in other than simple SPI mode and clock synchronous mode.

#### **CKPH Bit (Clock Phase Select)**

This bit selects the phase of the clock signal output through the SCKn pin. Refer to Figure 23.55 for details. Set the bit to 0 in other than simple SPI mode and clock synchronous mode.

### 23.2.17 Extended Serial Module Enable Register (ESMER)

Address(es): SCI12.ESMER 0008 B320h



| Bit      | Symbol | Bit Name                       | Description                                                                                                | R/W |
|----------|--------|--------------------------------|------------------------------------------------------------------------------------------------------------|-----|
| b0       | ESME   | Extended Serial Mode<br>Enable | <ul><li>0: The extended serial mode is disabled.</li><li>1: The extended serial mode is enabled.</li></ul> | R/W |
| b7 to b1 | _      | Reserved                       | These bits are read as 0. The write value should be 0.                                                     | R/W |

#### **ESME Bit (Extended Serial Mode Enable)**

When the ESME bit is 1, the facilities of the extended serial mode control section are enabled.

When the ESME bit is 0, the extended serial mode control section is initialized.

Table 23.25 Settings of the ESME Bit and Timer Operation Mode

| ESME Bit | Timer Mode  | Break Field Low Width Determination Mode | Break Field Low Width Output Mode |
|----------|-------------|------------------------------------------|-----------------------------------|
| 0        | Available*1 | Not available                            | Not available                     |
| 1        | Available   | Available                                | Available                         |

Note 1. Operation is only possible with PCLK selected.

# 23.2.18 Control Register 0 (CR0)

Address(es): SCI12.CR0 0008 B321h



| Bit      | Symbol | Bit Name                       | Description                                                                                | R/W |
|----------|--------|--------------------------------|--------------------------------------------------------------------------------------------|-----|
| b0       | _      | Reserved                       | This bit is read as 0. The write value should be 0.                                        | R/W |
| b1       | SFSF   | Start Frame Status Flag        | Start Frame detection function is disabled.     Start Frame detection function is enabled. | R   |
| b2       | RXDSF  | RXDX12 Input Status Flag       | 0: RXDX12 input is enabled. 1: RXDX12 input is disabled.                                   | R   |
| b3       | BRME   | Bit Rate Measurement<br>Enable | Measurement of bit rate is disabled.     Measurement of bit rate is enabled.               | R/W |
| b7 to b4 | _      | Reserved                       | These bits are read as 0. The write value should be 0.                                     | R/W |

# 23.2.19 Control Register 1 (CR1)

Address(es): SCI12.CR1 0008 B322h



| Bit      | Symbol     | Bit Name                                | Description                                                                                                                                                                                                                                                                                                       | R/W |
|----------|------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | BFE        | Break Field Enable                      | Break Field detection is disabled.     Break Field detection is enabled.                                                                                                                                                                                                                                          | R/W |
| b1       | CF0RE      | Control Field 0 Reception<br>Enable     | Reception of Control Field 0 is disabled.     Reception of Control Field 0 is enabled.                                                                                                                                                                                                                            | R/W |
| b3, b2   | CF1DS[1:0] | Control Field 1 Data Register<br>Select | <ul> <li>b3 b2</li> <li>0 0: Selects comparison with the value in PCF1DR.</li> <li>0 1: Selects comparison with the value in SCF1DR.</li> <li>1 0: Selects comparison with the values in PCF1DR and SCF1DR.</li> <li>1 1: Setting prohibited.</li> </ul>                                                          | R/W |
| b4       | PIBE       | Priority Interrupt Bit Enable           | O: The priority interrupt bit is disabled. The priority interrupt bit is enabled.                                                                                                                                                                                                                                 | R/W |
| b7 to b5 | PIBS[2:0]  | Priority Interrupt Bit Select           | b7 b5 0 0 0: 0th bit of Control Field 1 0 0 1: 1st bit of Control Field 1 0 1 0: 2nd bit of Control Field 1 0 1 1: 3rd bit of Control Field 1 1 0 0: 4th bit of Control Field 1 1 0 1: 5th bit of Control Field 1 1 0: 6th bit of Control Field 1 1 1: 7th bit of Control Field 1 1 1: 7th bit of Control Field 1 | R/W |

# 23.2.20 Control Register 2 (CR2)

Address(es): SCI12.CR2 0008 B323h



| Bit      | Symbol    | Bit Name                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R/W |
|----------|-----------|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b2 to b0 | DFCS[2:0] | RXDX12 Signal Digital Filter<br>Clock Select | b2 b0 0 0 0: Filter is disabled. 0 0 1: Filter clock is SCI base clock*1 0 1 0: Filter clock is PCLK/8 0 1 1: Filter clock is PCLK/16 1 0 0: Filter clock is PCLK/32 1 0 1: Filter clock is PCLK/64 1 1 0: Filter clock is PCLK/128 1 1 1: Setting prohibited                                                                                                                                                                                                                                       | R/W |
| b3       | _         | Reserved                                     | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R/W |
| b5, b4   | BCCS[1:0] | Bus Collision Detection Clock<br>Select      | b5 b4 0 0: SCI base clock 0 1: SCI base clock frequency divided by 2 1 0: SCI base clock frequency divided by 4 1 1: Setting prohibited                                                                                                                                                                                                                                                                                                                                                             | R/W |
| b7, b6   | RTS[1:0]  | RXDX12 Reception Sampling<br>Timing Select   | When SCI12.SEMR.ABCS = 0  b7 b6 0 0: Rising edge of the 8th cycle of SCI base clock 0 1: Rising edge of the 10th cycle of SCI base clock 1 0: Rising edge of the 12th cycle of SCI base clock 1 1: Rising edge of the 14th cycle of SCI base clock  When SCI12.SEMR.ABCS = 1  b7 b6 0 0: Rising edge of the 4th cycle of SCI base clock 0 1: Rising edge of the 5th cycle of SCI base clock 1 0: Rising edge of the 6th cycle of SCI base clock 1 1: Rising edge of the 7th cycle of SCI base clock | R/W |

Note: The period of the SCI base clock is 1/16 of a single bit period when the SCI12.SEMR.ABCS is 0, and 1/8 of a single bit period when the SCI12.SEMR.ABCS is 1.

Note 1. To use the SCI base clock, set the SCI12.SCR.TE bit to 1.

# 23.2.21 Control Register 3 (CR3)

Address(es): SCI12.CR3 0008 B324h



| Bit      | Symbol | Bit Name                    | Description                                                                           | R/W |
|----------|--------|-----------------------------|---------------------------------------------------------------------------------------|-----|
| b0       | SDST   | Start Frame Detection Start | Detection of Start Frame is not performed.     Detection of Start Frame is performed. | R/W |
| b7 to b1 | _      | Reserved                    | These bits are read as 0. The write value should be 0.                                | R/W |

#### **SDST Bit (Start Frame Detection Start)**

Detection of a Start Frame begins when this bit is set to 1. The bit is read as 0.

# 23.2.22 Port Control Register (PCR)

Address(es): SCI12.PCR 0008 B325h



| Bit      | Symbol | Bit Name                                 | Description                                                                                                            | R/W |
|----------|--------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | TXDXPS | TXDX12 Signal Polarity Select            | 0: The polarity of TXDX12 signal is not inverted for output.  1: The polarity of TXDX12 signal is inverted for output. | R/W |
| b1       | RXDXPS | RXDX12 Signal Polarity<br>Select         | 0: The polarity of RXDX12 signal is not inverted for input.  1: The polarity of RXDX12 signal is inverted for input.   | R/W |
| b3, b2   | _      | Reserved                                 | These bits are read as 0. The write value should be 0.                                                                 | R/W |
| b4       | SHARPS | TXDX12/RXDX12 Pin<br>Multiplexing Select | 0: The TXDX12 and RXDX12 pins are independent.  1: The TXDX12 and RXDX12 signals are multiplexed on the same pin.      | R/W |
| b7 to b5 | _      | Reserved                                 | These bits are read as 0. The write value should be 0.                                                                 | R/W |

#### SHARPS Bit (TXDX12/RXDX12 Pin Multiplexing Select)

When this bit is set to 1, the TXDX12 and RXDX12 signals are multiplexed on the same pin so that half-duplex communications become possible.

# 23.2.23 Interrupt Control Register (ICR)

Address(es): SCI12.ICR 0008 B326h



| Bit    | Symbol | Bit Name                                            | Description                                                                                                                                                                | R/W |
|--------|--------|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0     | BFDIE  | Break Field Low Width Detected<br>Interrupt Enable  | O: Interrupts on detection of the low width for a Break Field are disabled.  1: Interrupts on detection of the low width for a Break Field are enabled.                    | R/W |
| b1     | CF0MIE | Control Field 0 Match Detected<br>Interrupt Enable  | <ul><li>0: Interrupts on detection of a match with Control Field 0 are disabled.</li><li>1: Interrupts on detection of a match with Control Field 0 are enabled.</li></ul> | R/W |
| b2     | CF1MIE | Control Field 1 Match Detected<br>Interrupt Enable  | O: Interrupts on detection of a match with Control Field 1 are disabled.  1: Interrupts on detection of a match with Control Field 1 are enabled.                          | R/W |
| b3     | PIBDIE | Priority Interrupt Bit Detected Interrupt<br>Enable | O: Interrupts on detection of the priority interrupt bit are disabled.  1: Interrupts on detection of the priority interrupt bit are enabled.                              | R/W |
| b4     | BCDIE  | Bus Collision Detected Interrupt Enable             | O: Interrupts on detection of a bus collision are disabled.     I: Interrupts on detection of a bus collision are enabled.                                                 | R/W |
| b5     | AEDIE  | Valid Edge Detected Interrupt Enable                | O: Interrupts on detection of a valid edge are disabled.  1: Interrupts on detection of a valid edge are enabled.                                                          | R/W |
| b7, b6 | _      | Reserved                                            | These bits are read as 0. The write value should be 0.                                                                                                                     | R/W |

# 23.2.24 Status Register (STR)

Address(es): SCI12.STR 0008 B327h



| Bit    | Symbol | Bit Name                                 | Description                                                                                                                                                                                                              |   |  |  |  |  |  |  |
|--------|--------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--|--|--|--|--|
| b0     | BFDF   | Break Field Low Width<br>Detection Flag  | [Setting conditions]  • Detection of the low width for a Break Field  • Completion of the output of the low width for a Break Field  • Underflow of the timer [Clearing condition]  • Writing 1 to the BFDCL bit in STCR | R |  |  |  |  |  |  |
| b1     | CF0MF  | Control Field 0 Match<br>Flag            | <ul> <li>[Setting condition]</li> <li>A match between the value received in Control Field 0 and the set value.</li> <li>[Clearing condition]</li> <li>Writing 1 to the CF0MCL bit in STCR</li> </ul>                     | R |  |  |  |  |  |  |
| b2     | CF1MF  | Control Field 1 Match<br>Flag            | <ul> <li>[Setting condition]</li> <li>A match between the data received in Control Field 1 and the set values.</li> <li>[Clearing condition]</li> <li>Writing 1 to the CF1MCL bit in STCR</li> </ul>                     | R |  |  |  |  |  |  |
| b3     | PIBDF  | Priority Interrupt Bit<br>Detection Flag | [Setting condition]  • Detection of the priority interrupt bit [Clearing condition]  • Writing 1 to the PIBDCL bit in STCR                                                                                               | R |  |  |  |  |  |  |
| b4     | BCDF   | Bus Collision Detected<br>Flag           | [Setting condition]  • Detection of the bus collision [Clearing condition]  • Writing 1 to the BCDCL bit in STCR                                                                                                         | R |  |  |  |  |  |  |
| b5     | AEDF   | Valid Edge Detection<br>Flag             | [Setting condition]  • Detection of a valid edge [Clearing condition]  • Writing 1 to the AEDCL bit in STCR                                                                                                              | R |  |  |  |  |  |  |
| b7, b6 | _      | Reserved                                 | These bits are read as 0. The write value should be 0.                                                                                                                                                                   | R |  |  |  |  |  |  |

# 23.2.25 Status Clear Register (STCR)

Address(es): SCI12.STCR 0008 B328h



| Bit    | Symbol | Bit Name    | Description                                                             | R/W |
|--------|--------|-------------|-------------------------------------------------------------------------|-----|
| b0     | BFDCL  | BFDF Clear  | Setting this bit to 1 clears the STR.BFDF flag. This bit is read as 0.  | R/W |
| b1     | CF0MCL | CF0MF Clear | Setting this bit to 1 clears the STR.CF0MF flag. This bit is read as 0. | R/W |
| b2     | CF1MCL | CF1MF Clear | Setting this bit to 1 clears the STR.CF1MF flag. This bit is read as 0. | R/W |
| b3     | PIBDCL | PIBDF Clear | Setting this bit to 1 clears the STR.PIBDF flag. This bit is read as 0. | R/W |
| b4     | BCDCL  | BCDF Clear  | Setting this bit to 1 clears the STR.BCDF flag. This bit is read as 0.  | R/W |
| b5     | AEDCL  | AEDF Clear  | Setting this bit to 1 clears the STR.AEDF flag. This bit is read as 0.  | R/W |
| b7, b6 | _      | Reserved    | These bits are read as 0. The write value should be 0.                  | R/W |

# 23.2.26 Control Field 0 Data Register (CF0DR)

Address(es): SCI12.CF0DR 0008 B329h



The CF0DR register is an 8-bit readable and writable register that holds a value for comparison with Control Field 0.

# 23.2.27 Control Field 0 Compare Enable Register (CF0CR)

Address(es): SCI12.CF0CR 0008 B32Ah



| Bit | Symbol | Bit Name                             | Description                                                                                                                                | R/W |
|-----|--------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | CF0CE0 | Control Field 0 Bit 0 Compare Enable | <ul><li>0: Comparison with bit 0 of Control Field 0 is disabled.</li><li>1: Comparison with bit 0 of Control Field 0 is enabled.</li></ul> | R/W |
| b1  | CF0CE1 | Control Field 0 Bit 1 Compare Enable | Comparison with bit 1 of Control Field 0 is disabled.     Comparison with bit 1 of Control Field 0 is enabled.                             | R/W |
| b2  | CF0CE2 | Control Field 0 Bit 2 Compare Enable | Comparison with bit 2 of Control Field 0 is disabled.     Comparison with bit 2 of Control Field 0 is enabled.                             | R/W |
| b3  | CF0CE3 | Control Field 0 Bit 3 Compare Enable | <ul><li>0: Comparison with bit 3 of Control Field 0 is disabled.</li><li>1: Comparison with bit 3 of Control Field 0 is enabled.</li></ul> | R/W |
| b4  | CF0CE4 | Control Field 0 Bit 4 Compare Enable | Comparison with bit 4 of Control Field 0 is disabled.     Comparison with bit 4 of Control Field 0 is enabled.                             | R/W |
| b5  | CF0CE5 | Control Field 0 Bit 5 Compare Enable | <ul><li>0: Comparison with bit 5 of Control Field 0 is disabled.</li><li>1: Comparison with bit 5 of Control Field 0 is enabled.</li></ul> | R/W |
| b6  | CF0CE6 | Control Field 0 Bit 6 Compare Enable | Comparison with bit 6 of Control Field 0 is disabled.     Comparison with bit 6 of Control Field 0 is enabled.                             | R/W |
| b7  | CF0CE7 | Control Field 0 Bit 7 Compare Enable | <ul><li>0: Comparison with bit 7 of Control Field 0 is disabled.</li><li>1: Comparison with bit 7 of Control Field 0 is enabled.</li></ul> | R/W |

# 23.2.28 Control Field 0 Receive Data Register (CF0RR)

Address(es): SCI12.CF0RR 0008 B32Bh



CF0RR is a readable register that holds the value received in Control Field 0. Writing to this register from the CPU or DTC is not possible.

# 23.2.29 Primary Control Field 1 Data Register (PCF1DR)

Address(es): SCI12.PCF1DR 0008 B32Ch



 $PCF1DR \ is \ an \ 8-bit \ readable \ and \ writable \ register \ that \ holds \ the \ 8-bit \ primary \ value \ for \ comparison \ with \ Control \ Field \ 1.$ 



# 23.2.30 Secondary Control Field 1 Data Register (SCF1DR)

Address(es): SCI12.SCF1DR 0008 B32Dh



PCF1DR is an 8-bit readable and writable register that holds the 8-bit secondary value for comparison with Control Field 1.

# 23.2.31 Control Field 1 Compare Enable Register (CF1CR)

Address(es): SCI12.CF1CR 0008 B32Eh

| _               | b7         | b6         | b5         | b4         | b3    | b2         | b1         | b0         |
|-----------------|------------|------------|------------|------------|-------|------------|------------|------------|
|                 | CF1CE<br>7 | CF1CE<br>6 | CF1CE<br>5 | CF1CE<br>4 | CF1CE | CF1CE<br>2 | CF1CE<br>1 | CF1CE<br>0 |
| in after recet: | Λ          | Λ          | Λ          | Λ          | Λ     | Λ          | Λ          | Λ          |

| Bit | Symbol | Bit Name                             | Description                                                                                                                                | R/W |
|-----|--------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | CF1CE0 | Control Field 1 Bit 0 Compare Enable | Comparison with bit 0 of Control Field 1 is disabled.     Comparison with bit 0 of Control Field 1 is enabled.                             | R/W |
| b1  | CF1CE1 | Control Field 1 Bit 1 Compare Enable | Comparison with bit 1 of Control Field 1 is disabled.     Comparison with bit 1 of Control Field 1 is enabled.                             | R/W |
| b2  | CF1CE2 | Control Field 1 Bit 2 Compare Enable | Comparison with bit 2 of Control Field 1 is disabled.     Comparison with bit 2 of Control Field 1 is enabled.                             | R/W |
| b3  | CF1CE3 | Control Field 1 Bit 3 Compare Enable | Comparison with bit 3 of Control Field 1 is disabled.     Comparison with bit 3 of Control Field 1 is enabled.                             | R/W |
| b4  | CF1CE4 | Control Field 1 Bit 4 Compare Enable | Comparison with bit 4 of Control Field 1 is disabled.     Comparison with bit 4 of Control Field 1 is enabled.                             | R/W |
| b5  | CF1CE5 | Control Field 1 Bit 5 Compare Enable | <ul><li>0: Comparison with bit 5 of Control Field 1 is disabled.</li><li>1: Comparison with bit 5 of Control Field 1 is enabled.</li></ul> | R/W |
| b6  | CF1CE6 | Control Field 1 Bit 6 Compare Enable | <ul><li>0: Comparison with bit 6 of Control Field 1 is disabled.</li><li>1: Comparison with bit 6 of Control Field 1 is enabled.</li></ul> | R/W |
| b6  | CF1CE7 | Control Field 1 Bit 7 Compare Enable | <ul><li>0: Comparison with bit 7 of Control Field 1 is disabled.</li><li>1: Comparison with bit 7 of Control Field 1 is enabled.</li></ul> | R/W |

# 23.2.32 Control Field 1 Receive Data Register (CF1RR)

Address(es): SCI12.CF1RR 0008 B32Fh



CF1RR is a readable register that holds the value received in Control Field 1. Writing to this register from the CPU or DTC is not possible.



# 23.2.33 Timer Control Register (TCR)

Address(es): SCI12.TCR 0008 B330h



| Bit      | Symbol | Bit Name          | Description                                            | R/W |
|----------|--------|-------------------|--------------------------------------------------------|-----|
| b0       | TCST   | Timer Count Start | Stops the timer counting     Starts the timer counting | R/W |
| b7 to b1 | _      | Reserved          | These bits are read as 0. The write value should be 0. | R/W |

# 23.2.34 Timer Mode Register (TMR)

Address(es): SCI12.TMR 0008 B331h



| Bit                                            | Symbol    | Bit Name                          | Description                                                                                                                                      | R/W |
|------------------------------------------------|-----------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1, b0 TOMS[1:0] Timer Operating Mode Select*1 |           | Timer Operating Mode Select*1     | b1 b0 0 0: Timer mode 0 1: Break Field low width determination mode 1 0: Break Field low width output mode 1 1: Setting prohibited               | R/W |
| b2                                             | _         | Reserved                          | This bit is read as 0. The write value should be 0.                                                                                              | R/W |
| b3                                             | TWRC      | Counter Write Control             | O: Data is written to the reload register and counter Data is written to the reload register only                                                | R/W |
| b6 to b4                                       | TCSS[2:0] | Timer Count Clock Source Select*1 | b6 b4<br>0 0 0: PCLK<br>0 0 1: PCLK/2<br>0 1 0: PCLK/4<br>0 1 1: PCLK/8<br>1 0 0: PCLK/16<br>1 0 1: PCLK/32<br>1 1 0: PCLK/64<br>1 1 1: PCLK/128 | R/W |
| b7                                             | _         | Reserved                          | This bit is read as 0. The write value should be 0.                                                                                              | R/W |

Note 1. Rewrite the TOMS[1:0] and TCSS[2:0] bits only when the timer is stopped (TCST = 0).

#### **TWRC Bit (Counter Write Control)**

This bit determines whether a value written to TPRE or TCNT is written to the reload register only or is written to both the reload register and the counter.

# 23.2.35 Timer Prescaler Register (TPRE)

Address(es): SCI12.TPRE 0008 B332h



TPRE consists of an 8-bit reload register, a read buffer, and a counter, each of which has FFh as its initial value. The counter counts down in synchronization with the counter clock selected by the TMR.TCSS[2:0] bits, and is reloaded with the value in the reload register when it underflows. Underflows of this register provide the clock source to drive counting by the TCNT register. The reload register and read buffer are allocated to the same address. Data is written to the reload register in writing, and the counter value that has been transferred to the read buffer is returned in reading. It takes one PCLK cycle to load a value from the reload register to the counter.

# 23.2.36 Timer Count Register (TCNT)

Address(es): SCI12.TCNT 0008 B333h



TCNT consists of an 8-bit reload register, a read buffer, and a counter, each of which has FFh as its initial value. This down-counter counts underflows of the TPRE register until the TCNT register underflows, and is then reloaded with the value from the reload register. The reload register and read buffer are allocated to the same address. Data is written to the reload register in writing, and the counter value that has been transferred to the read buffer is returned in reading. It takes one PCLK cycle to load a value from the reload register to the counter.

# 23.3 Operation in Asynchronous Mode

Figure 23.4 shows the general format for asynchronous serial communications.

One frame consists of a start bit (low level), transmit/receive data, a parity bit, and stop bits (high level).

In asynchronous serial communications, the communications line is usually held in the mark state (high level).

The SCI monitors the communications line. When the SCI detects a low, it regards that as a start bit and starts serial communication.

Inside the SCI, the transmitter and receiver are independent units, enabling full-duplex communications. Both the transmitter and the receiver also have a double-buffered structure, so that data can be read or written during transmission or reception, enabling continuous data transmission and reception.



Figure 23.4 Data Format in Asynchronous Serial Communications (Example with 8-Bit Data, Parity, 2 Stop Bits)

### 23.3.1 Serial Data Transfer Format

Table 23.26 lists the serial data transfer formats that can be used in asynchronous mode.

Any of 12 transfer formats can be selected according to the SMR setting. For details of multi-processor function, refer to section 23.4, Multi-Processor Communications Function.

Table 23.26 Serial Transfer Formats (Asynchronous Mode)

| SMR Setting |     |    |      |   |   |   | Se | rial | Transf   | er For | mat | and Fı | ame | _ength |      |      |      |
|-------------|-----|----|------|---|---|---|----|------|----------|--------|-----|--------|-----|--------|------|------|------|
| CHR         | PE  | MP | STOP | 1 | 2 | 3 | 4  |      | 5        | 6      | l   | 7      | 8   | 9      | 10   | 11   | 12   |
| 0           | 0   | 0  | 0    | S |   |   |    |      | 8-bit    | data   |     |        |     |        | STOP |      |      |
| 0           | 0   | 0  | 1    | S |   |   |    |      | 8-bit    | data   |     |        |     |        | STOP | STOP |      |
| 0           | 1   | 0  | 0    | s |   |   |    |      | 8-bit    | data   |     |        |     |        | Р    | STOP |      |
| 0           | 1   | 0  | 1    | S |   |   |    |      | 8-bit    | data   |     |        |     |        | Р    | STOP | STOP |
| 1           | 0   | 0  | 0    | S |   |   |    | 7-l  | oit data | 1      |     |        |     | STOP   | -    |      |      |
| 1           | 0   | 0  | 1    | S |   |   |    | 7-l  | oit data | 1      |     |        |     | STOP   | STOP |      |      |
| 1           | 1   | 0  | 0    | s |   |   |    | 7-l  | oit data | 1      |     |        |     | Р      | STOP |      |      |
| 1           | 1   | 0  | 1    | s |   |   |    | 7-l  | oit data | 1      |     |        |     | Р      | STOP | STOP |      |
| 0           | _   | 1  | 0    | S |   |   |    |      | 8-bit    | data   |     |        |     |        | MPB  | STOP |      |
| 0           | _   | 1  | 1    | s |   |   |    |      | 8-bit    | data   |     |        |     |        | МРВ  | STOP | STOP |
| 1           | _   | 1  | 0    | s |   |   |    | 7-l  | oit data | 1      |     |        |     | MPB    | STOP |      |      |
| 1           | _   | 1  | 1    | S |   |   |    | 7-k  | oit data | 1      |     |        |     | MPB    | STOP | STOP |      |
|             | 011 |    | L    |   |   |   |    |      |          |        |     |        |     |        |      |      |      |

S: Start bit STOP: Stop bit P: Parity bit

MPB: Multi-processor bit

# 23.3.2 Receive Data Sampling Timing and Reception Margin in Asynchronous Mode

In asynchronous mode, the SCI operates on a base clock with a frequency of 16 times\*1 the bit rate.

In reception, the SCI samples the falling edge of the start bit using the base clock, and performs internal synchronization. Since receive data is sampled at the rising edge of the 8th pulse\*1 of the base clock, data is latched at the middle of each bit, as shown in Figure 23.5. Thus the reception margin in asynchronous mode is determined by formula (1) below.

$$M = \left| (0.5 - \frac{1}{2N}) - (L - 0.5) F - \frac{D - 0.5}{N} (1 + F) \right| \times 100 [\%] \cdots Formula (1)$$

M: Reception margin

N: Ratio of bit rate to clock (N = 16 when ABCS in SEMR = 0, N = 8 when ABCS in SEMR = 1)

D: Duty cycle of clock (D = 0.5 to 1.0)

L: Frame length (L = 9 to 13)

F: Absolute value of clock frequency deviation

Assuming values of F = 0 and D = 0.5 in formula (1), the reception margin is determined by the formula below.

$$M = \{0.5 - 1/(2 \times 16)\} \times 100 (\%) = 46.875\%$$

However, this is only the computed value, and a margin of 20% to 30% should be allowed in system design.

Note 1. This is an example when the ABCS bit in the SEMR register is 0. When the ABCS bit is 1, a frequency of 8 times the bit rate is used as a base clock and receive data is sampled at the rising edge of the 4th pulse of the base clock.



Figure 23.5 Receive Data Sampling Timing in Asynchronous Mode

#### 23.3.3 Clock

Either an internal clock generated by the on-chip baud rate generator or an external clock input to the SCKn pin can be selected as the SCI's transfer clock, according to the setting of the CM bit in the SMR register and the CKE[1:0] bits in the SCR register.

When an external clock is input to the SCKn pin, the clock frequency should be 16 times the bit rate (when SEMR.ABCS bit = 0) and 8 times the bit rate (when SEMR.ABCS bit = 1). In addition, when an external clock is specified, the base clock of MTIOC1A and MTIOC2A can be selected by the SCIn.SEMR.ACS0 bit (n = 1, 5, 12).

When the SCI is operated on an internal clock, the clock can be output from the SCKn pin. The frequency of the clock output in this case is equal to the bit rate, and the phase is such that the rising edge of the clock is in the middle of the transmit data, as shown in Figure 23.6.



Figure 23.6 Phase Relationship between Output Clock and Transmit Data (Asynchronous Mode: SMR.CHR = 0, PE = 1, MP = 0, STOP = 1)

#### 23.3.4 CTS and RTS Functions

The CTS function is the use of input on the CTSn# pin in transmission control. Setting the SPMR.CTSE bit to 1 enables the CTS function. When the CTS function is enabled, placing the low level on the CTSn# pin causes transmission to start.

Applying the high level to the CTS# pin while transmission is in progress does not affect transmission of the current frame, which continues.

In the RTS function, by using the function of output on the RTSn# pin, a low level is output when reception becomes possible. Conditions for output of the low and high level are shown below.

[Conditions for low-level output]

When the following conditions are all satisfied

- The SCR.RE bit is 1
- Reception is not in progress
- There are no received data yet to be read
- The ORER, FER, and PER flags in the SSR are all 0

[Condition for high-level output]

When the conditions for low-level output are not satisfied

Note that either one of CTS and RTS can be selected.

# 23.3.5 SCI Initialization (Asynchronous Mode)

Before transmitting and receiving data, start by writing the initial value 00h to the SCR register and then continue through the procedure for SCI given in Figure 23.7. Whenever the operating mode or transfer format is changed, the SCR register must be initialized before the change is made.

When the external clock is used in asynchronous mode, ensure that the clock signal is supplied even during initialization. Note that setting the SCR.RE bit to 0 initializes neither the ORER, FER, PER, and RDRF flags in the SSR register nor the RDR register.

Moreover, note that changing the value of the SCR.TE bit from 1 to 0 or 0 to 1 while the SCR.TIE bit is 1 leads to the generation of a transmit data empty interrupt (TXI) request.

In addition, note that setting bits TIE, TE, and TEIE in the SCR register to 1 simultaneously leads to the generation of a transmit end interrupt (TEI) request before the generation of a TXI interrupt request.



Figure 23.7 Sample SCI Initialization Flowchart (Asynchronous Mode)

# 23.3.6 Serial Data Transmission (Asynchronous Mode)

Figure 23.8 to Figure 23.10 show an example of the operation for serial transmission in asynchronous mode. In serial transmission, the SCI operates as described below.

- 1. The SCI transfers data from the TDR register to the TSR register when data is written to the TDR register in the TXI interrupt handling routine. The TXI interrupt request at the beginning of transmission is generated when the SCR.TE bit is set to 1 after the SCR.TIE bit is set to 1 or when these 2 bits are set to 1 simultaneously by a single instruction.
- 2. Transmission starts after the SPMR.CTSE bit is set to 0 (CTS function is disabled) and a low level on the CTSn# pin causes data transfer from the TDR register to the TSR register. If the SCR.TIE bit is 1 at this time, a TXI interrupt request is generated. Continuous transmission is obtainable by writing the next transmit data to the TDR register in the TXI interrupt handling routine before transmission of the current transmit data is completed. When TEI interrupt requests are in use, set the SCR.TIE bit to 0 (a TXI interrupt request is disabled) and the SCR.TEIE bit to 1 (a TEI interrupt request is enabled) after the last of the data to be transmitted are written to the TDR register from the handling routine for TXI requests.
- 3. Data is sent from the TXDn pin in the following order: start bit, transmit data, parity bit or multi-processor bit (may be omitted depending on the format), and stop bit.
- 4. The SCI checks for updating of (writing to) the TDR register at the time of stop bit output.
- 5. When the TDR register is updated, setting of the SPMR.CTSE bit to 0 (CTS function is disabled) or a low level input on the CTSn# pin cause the next transfer of the next transmit data from the TDR register to the TSR register and sending of the stop bit, after which serial transmission of the next frame starts.
- 6. If the TDR register is not updated, the SSR.TEND flag is set to 1, the stop bit is sent, and then the mark state is entered in which 1 is output. If the SCR.TEIE bit is 1 at this time, the SSR.TEND flag is set to 1 and a TEI interrupt request is generated.

Figure 23.11 shows a sample flowchart for serial transmission in asynchronous mode.



Figure 23.8 Example of Operation for Serial Transmission in Asynchronous Mode (1)
(with 8-Bit Data, Parity, 1 Stop Bit, CTS Function Not Used, at the Beginning of Transmission)



Figure 23.9 Example of Operation for Serial Transmission in Asynchronous Mode (2) (with 8-Bit Data, Parity, 1 Stop Bit, CTS Function Used, at the Beginning of Transmission)



Figure 23.10 Example of Operation for Serial Transmission in Asynchronous Mode (3)
(with 8-Bit Data, Parity, 1 Stop Bit, CTS Function Not Used, from the Middle of Transmission until Transmission Completion)



Figure 23.11 Example of Serial Transmission Flowchart in Asynchronous Mode

# 23.3.7 Serial Data Reception (Asynchronous Mode)

Figure 23.12 and Figure 23.13 show an example of the operation for serial data reception in asynchronous mode. In serial data reception, the SCI operates as described below.

- 1. When the value of the SCR.RE bit becomes 1, the output signal on the RTSn# pin goes to the low level.
- 2. When the SCI monitors the communications line and detects a start bit, it performs internal synchronization, stores receive data in the RSR register, and checks the parity bit and stop bit.
- 3. If an overrun error occurs, the SSR.ORER flag is set to 1. If the SCR.RIE bit is 1 at this time, an ERI interrupt request is generated. Receive data is not transferred to the RDR register.
- 4. If a parity error is detected, the SSR.PER flag is set to 1 and receive data is transferred to the RDR register. If the SCR.RIE bit is 1 at this time, an ERI interrupt request is generated.
- 5. If a framing error (when the stop bit is 0) is detected, the SSR.FER flag is set to 1 and receive data is transferred to the RDR register. If the SCR.RIE bit is 1 at this time, an ERI interrupt request is generated.
- 6. When reception finishes successfully, receive data is transferred to the RDR register. If the SCR.RIE bit is 1 at this time, an RXI interrupt request is generated. Continuous reception is enabled by reading the receive data transferred to the RDR register in this RXI interrupt handling routine before reception of the next receive data is completed. Reading the received data that have been transferred to the RDR register causes the RTSn# pin to output the low level.



Figure 23.12 Example of SCI Operation for Serial Reception in Asynchronous Mode (1) (When RTS Function is Not Used) (Example with 8-Bit Data, Parity, 1 Stop Bit)



Figure 23.13 Example of SCI Operation for Serial Reception in Asynchronous Mode (2) (When RTS Function is Used) (Example with 8-Bit Data, Parity, 1 Stop Bit)

Table 23.27 lists the states of the flags in the SSR status register and receive data handling when a receive error is detected.

If a receive error is detected, an ERI interrupt request is generated but an RXI interrupt request is not generated. Data reception cannot be resumed while the receive error flag is 1. Accordingly, set the ORER, FER, and PER bits to 0 before resuming reception. Moreover, be sure to read the RDR during overrun error processing. When a reception is forcibly terminated by setting the SCR.RE bit to 0 during operation, read the RDR register because received data which has not yet been read may be left in RDR.

Figure 23.14 and Figure 23.15 show samples of flowcharts for serial data reception.

Table 23.27 Flags in the SSR Status Register and Receive Data Handling

| Flags in the SSR Status Register |     |     |                    |                                              |
|----------------------------------|-----|-----|--------------------|----------------------------------------------|
| ORER                             | FER | PER | Receive Data       | Receive Error Type                           |
| 1                                | 0   | 0   | Lost               | Overrun error                                |
| 0                                | 1   | 0   | Transferred to RDR | Framing error                                |
| 0                                | 0   | 1   | Transferred to RDR | Parity error                                 |
| 1                                | 1   | 0   | Lost               | Overrun error + framing error                |
| 1                                | 0   | 1   | Lost               | Overrun error + parity error                 |
| 0                                | 1   | 1   | Transferred to RDR | Framing error + parity error                 |
| 1                                | 1   | 1   | Lost               | Overrun error + framing error + parity error |



Figure 23.14 Example Flowchart of Serial Reception in Asynchronous Mode (1)



Figure 23.15 Example Flowchart of Serial Reception in Asynchronous Mode (2)

#### 23.4 Multi-Processor Communications Function

Using the multi-processor communication functions enables to transmit and receive data by sharing a communication line between multiple processors by using asynchronous serial communication in which the multi-processor bit is added. In multi-processor communication, a unique ID code is allocated to each receiving station. Serial communication cycles consist of an ID transmission cycle to specify the receiving station and a data transmission cycle to transmit data to the specified receiving station. The multi-processor bit is used to distinguish between the ID transmission cycle and the data transmission cycle. When the multi-processor bit is set to 1, it indicates the ID transmission cycle and when the multiprocessor bit is set to 0, it indicates the data transmission cycle. Figure 23.16 shows an example of communication between processors by using a multi-processor format. First, a transmitting station transmits communication data in which the multi-processor bit set to 1 is added to the ID code of the receiving station. Next, the transmitting station transmits the communication data in which the multi-processor bit set to 0 is added to the transmit data. Upon receiving the communication data in which the multi-processor bit is set to 1, the receiving station compares the received ID with the ID of the receiving station itself and if the two match, receives the communication data that is subsequently transmitted. If the received ID does not match with the ID of the receiving station, the receiving station skips the communication data until again receiving the communication data in which the multi-processor bit is set to 1. For supporting this function, the SCI provides the SCR.MPIE bit. When the MPIE bit is set to 1, transfer of receive data from the RSR register to the RDR register, detection of a receive error, and setting the respective status flags ORER and FER in the SSR register are disabled until reception of data in which the multi-processor bit is set to 1. Upon receiving a reception character in which the multi-processor bit is set to 1, the SSR.MPB bit is set to 1 and the SCR.MPIE bit is automatically cleared, thus returning to a normal reception operation. During this time, an RXI interrupt is generated if the SCR.RIE bit is 1.

When the multi-processor format is specified, specification of the parity bit is disabled. Apart from this, there is no difference from the operation in the normal asynchronous mode. A clock which is used for the multi-processor communication is also the same as the clock used in the normal asynchronous mode.



Figure 23.16 An Example of Communication using the Multi-Processor Format (Example of Transmission of Data AAh to Receiving Station A)

#### 23.4.1 Multi-Processor Serial Data Transmission

Figure 23.17 is a sample flowchart of multi-processor data transmission. In the ID transmission cycle, the ID should be transmitted with the SSR.MPBT bit set to 1. In the data transmission cycle, the data should be transmitted with the MPBT bit set to 0. The other operations are the same as the operations in asynchronous mode.



Figure 23.17 Example of Multi-Processor Serial Transmission Flowchart

# 23.4.2 Multi-Processor Serial Data Reception

Figure 23.19 and Figure 23.20 are sample flowcharts of multi-processor data reception. When the SCR.MPIE bit is set to 1, reading the communication data is skipped until reception of the communication data in which the multi-processor bit is set to 1. When the communication data in which the multi-processor bit is set to 1 is received, the received data is transferred to RDR. During this time, the RXI interrupt request is generated. The other operations are the same as the operations in asynchronous mode.

Figure 23.18 is the example of operation for reception.



Figure 23.18 Example of SCI Reception (8-Bit Data/Multi-Processor Bit/1 Stop Bit)



Figure 23.19 Example of Multi-Processor Serial Reception Flowchart (1)



Figure 23.20 Example of Multi-Processor Serial Reception Flowchart (2)

#### 23.5 Operation in Clock Synchronous Mode

Figure 23.21 shows the data format for clock synchronous serial data communications.

In clock synchronous mode, data is transmitted or received in synchronization with clock pulses. One character in transfer data consists of 8-bit data. In clock synchronous mode, no parity bit can be added.

In data transmission, the SCI outputs data from one falling edge of the synchronization clock to the next. In data reception, the SCI receives data in synchronization with the rising edge of the synchronization clock. After 8-bit data is output, the communication line holds the last bit output state.

Inside the SCI, the transmitter and receiver are independent units, enabling full-duplex communications by use of a common clock. Both the transmitter and the receiver also have a double-buffered structure, so that the next transmit data can be written during transmission or the previous receive data can be read during reception, enabling continuous data transfer.



Figure 23.21 Data Format in Clock Synchronous Serial Communications (LSB First)

#### 23.5.1 Clock

Either an internal clock generated by the on-chip baud rate generator or an external synchronization clock input at the SCKn pin can be selected, according to the setting of the SCR.CKE[1:0] bits.

When the SCI is operated on an internal clock, the synchronization clock is output from the SCKn pin. Eight synchronization clock pulses are output in the transfer of one character, and when no transfer is performed the clock is held high. However, when only data reception is performed while the CTS function is disabled, the synchronization clock output is started at the same time when the SCR.RE bit set to 1. The synchronization clock is stopped at the high level when an overrun error occurs or the SCR.RE bit is set to 0.

When only data reception is performed and the CTS function is enabled, the clock output is not started even when the SCR.RE bit set to 1 if the CTSn# pin input is high when the SCR.RE bit is 0. The synchronization clock output is started when the SCR.RE bit is set to 1 and the CTSn# pin input is low. After that, if the CTSn# pin input is high on completion of the frame reception, the synchronization clock output is stopped at the high level. If the CTSn# pin input continues to be low, the synchronization clock is stopped at the high level when an overrun error occurs or the SCR.RE bit is set to 0.

#### 23.5.2 CTS and RTS Functions

In the CTS function, CTSn# pin input is used to control reception/transmission start when the clock source is the internal clock. Setting the SPMR.CTSE bit to 1 enables the CTS function.

When the CTS function is enabled, placing the low level on the CTSn# pin causes reception/transmission to start. Applying the high level to the CTS# pin while reception/transmission are in progress does not affect reception/transmission of the current frame, which continues.

In the RTS function, RTSn# pin output is used to request reception/transmission start when the clock source is an external synchronizing clock. A low level is output when serial communications become possible. Conditions for output of the low and high level are shown below.

[Conditions for low-level output]

When the following conditions are all satisfied

- The SCR.RE or SCR.TE bit is 1
- Transmission or reception of data is not in progress
- There are no received data yet to be read (when the SCR.RE bit is 1)
- Transmit data has been written (when the SCR.TE bit is 1)
- The SSR.ORER flag is 0

[Condition for high-level output]

The conditions for low-level output have not been satisfied.

# 23.5.3 SCI Initialization (Clock Synchronous Mode)

Before transmitting and receiving data, start by writing the initial value 00h to the SCR register and then continue through the procedure for SCI given in Figure 23.22. Whenever the operating mode or transfer format is changed, the SCR register must be initialized before the change is made.

Note that setting the SCR.RE bit to 0 initializes neither the ORER, FER, and PER flags in the SSR register nor the RDR register.

Moreover, note that switching the value of the SCR.TE bit from 1 to 0 or 0 to 1 while the SCR.TIE bit is 1 leads to the generation of a TXI interrupt request.



Figure 23.22 Example of SCI Initialization Flowchart (Clock Synchronous Mode)

# 23.5.4 Serial Data Transmission (Clock Synchronous Mode)

Figure 23.22, Figure 23.23, and Figure 23.24 show an example of the operation for serial transmission in clock synchronous mode.

In serial data transmission, the SCI operates as described below.

- 1. The SCI transfers data from TDR to TSR when data is written to TDR in the TXI interrupt handling routine. The TXI interrupt request at the beginning of transmission is generated when the TE bit in the SCR register is set to 1 after the TIE bit in the SCR register is set to 1 or when these 2 bits are set to 1 simultaneously by a single instruction.
- 2. After transferring data from the TDR register to the TSR register, the SCI starts transmission. When the SCR.TIE bit is set to 1 at this time, a TXI interrupt request is generated. Continuous transmission is enabled by writing the next transmit data to the TDR register in this TXI interrupt handling routine before transmission of the current transmit data has finished. When TEI interrupt requests are in use, set the SCR.TIE bit to 0 (a TXI interrupt request is disabled) and the SCR.TEIE bit to 1 (a TEI interrupt request is enabled) after the last of the data to be transmitted are written to the TDR register from the handling routine for TXI requests.
- 3. 8-bit data is sent from the TXDn pin in synchronization with the output clock when clock output mode has been specified and in synchronization with the input clock when use of an external clock has been specified. Output of the clock signal is suspended until the input CTS signal is at the low level while the CTSE bit in the SPMR register is 1 (CTS function is enabled).
- 4. The SCI checks for updating of (writing to) the TDR register at the time of the last bit output.
- 5. When TDR is updated, the next transmit data is transferred from the TDR register to the TSR register, and serial transmission of the next frame is started.
- 6. If the TDR register is not updated, set the SSR.TEND flag to 1 and the TXDn pin retains the output state of the last bit. If the TEIE bit in the SCR register is 1 at this time, a TEI interrupt request is generated. The SCKn pin is held high.

Figure 23.26 shows a sample flowchart of serial data transmission.

Transmission will not start while a receive error flag (ORER, FER, or PER in the SSR register) is set to 1. Be sure to set the receive error flags to 0 before starting transmission. Note that setting the RE bit in the SCR register to 0 does not clear the receive error flags.



Figure 23.23 Example of Serial Data Transmission in Clock Synchronous Mode When the CTS Function is Not Used at the Beginning of Transmission



Figure 23.24 Example of Serial Data Transmission in Clock Synchronous Mode When the CTS Function is Used at the Beginning of Transmission



Figure 23.25 Example of Serial Data Transmission in Clock Synchronous Mode from the Middle of Transmission until Transmission Completion



- [1] SCI initialization: Set data transmission.
- [2] Writing transmit data write to TDR by a TXI interrupt request:

When transmit data is transferred from TDR to TSR, a transmit data empty interrupt (TXI) request is generated.

Transmit data is written to TDR once from the handling routine for TXI requests.

[ 3 ] Serial transmission continuation procedure: To continue serial transmission, write transmit data to TDR upon accepting a transmit data empty interrupt (TXI) request. Transmit data can also be written to TDR by activating the DTC by the TXI interrupt request. When TEI interrupt requests are in use, set the SCR.TIE bit to 0 and the SCR.TEIE bit to 1 after the last of the data to be transmitted are written to the TDR.

Note: When the external clock is in use (the value of the SCR.CKE[1:0] bits is 10b or 11b), the rising edge on the SCK pin for the last bit sets the SSR.TEND flag to 1. Setting the SCR.TE bit to 0 immediately after this may lead to insufficient received-data hold time on the receiver side.

Figure 23.26 Example Flowchart of Serial Transmission in Clock Synchronous Mode

# 23.5.5 Serial Data Reception (Clock Synchronous Mode)

Figure 23.27 and Figure 23.28 show an example of SCI operation for serial reception in clock synchronous mode. In serial data reception, the SCI operates as described below.

- 1. The value of the RE bit in the SCR register becoming 1 places the signal output on the RTSn# pin at the low level (when the RTS function is in use).
- 2. The SCI performs internal initialization and starts receiving data in synchronization with a synchronization clock input or output, and stores the receive data in the RSR register.
- 3. If an overrun error occurs, the ORER bit in the SSR register is set to 1. If the RIE bit in the SCR register is 1 at this time, an ERI interrupt request is generated. Receive data is not transferred to the RDR register.
- 4. When reception finishes successfully, receive data is transferred to the RDR register. If the RIE bit in the SCR register is 1 at this time, an RXI interrupt request is generated. Continuous reception is enabled by reading the receive data transferred to the RDR register in this RXI interrupt handling routine before reception of the next receive data is completed. Reading out the received data that have been transferred to the RDR register causes the RTSn# pin to output the low level (when the RTS function is in use).



Figure 23.27 Example of Operation for Serial Reception in Clock Synchronous Mode (1) (When RTS Function is Not Used)



Figure 23.28 Example of Operation for Serial Reception in Clock Synchronous Mode (2) (When RTS Function is Used)

Data transfer cannot be resumed while a receive error flag is 1. Accordingly, clear the ORER, FER, and PER bits in the SSR register to 0 before resuming reception. Moreover, be sure to read the RDR register during overrun error processing. When a reception is forcibly terminated by setting the SCR.RE bit to 0 during operation, read the RDR register because received data which has not yet been read may be left in the RDR register.

Figure 23.29 shows a sample flowchart for serial data reception.



Figure 23.29 Example Flowchart of Serial Reception in Clock Synchronous Mode

# 23.5.6 Simultaneous Serial Data Transmission and Reception (Clock Synchronous Mode)

Figure 23.30 shows a sample flowchart for simultaneous serial transmit and receive operations in clock synchronous mode.

After initializing the SCI, the following procedure should be used for simultaneous serial data transmit and receive operations.

To switch from transmit mode to simultaneous transmit and receive mode, check that the SCI has finished transmission by reading that the TEND flag in the SSR register is 1, and then initialize the SCR register. Then set the TIE, RIE, TE, and RE bits in the SCR register to 1 simultaneously by a single instruction.

To switch from receive mode to simultaneous transmit and receive mode, check that the SCI has finished reception, and then set the RIE and RE bits to 0. Then check that the receive error flags (ORER, FER, and PER in the SSR register) are 0, and then set the TIE, RIE, TE, and RE bits in the SCR register to 1 simultaneously by a single instruction.



Figure 23.30 Example Flowchart of Simultaneous Serial Transmission and Reception in Clock Synchronous Mode

# 23.6 Operation in Smart Card Interface Mode

The SCI supports smart card (IC card) interfaces conforming to ISO/IEC 7816-3 (standard for Identification Cards), as an extended function of the SCI.

Smart card interface mode can be selected using the appropriate register.

# 23.6.1 Sample Connection

Figure 23.31 shows a sample connection between a smart card (IC card) and this MCU.

As in the figure, since this MCU communicates with an IC card using a single transmission line, interconnect the TXDn and RXDn pins and pull up the data transmission line to VCC using a resistor.

Setting the TE and RE bits in the SCR register to 1 with an IC card disconnected enables closed transmission/reception allowing self-diagnosis.

To supply an IC card with the clock pulses generated by the SCI, input the SCKn pin output to the CLK pin of an IC card. The output port of the this MCU can be used to output a reset signal.



Figure 23.31 Sample Connection with a Smart Card (IC Card)

# 23.6.2 Data Format (Except in Block Transfer Mode)

Figure 23.32 shows the data transfer formats in smart card interface mode.

- One frame consists of 8-bit data and a parity bit in asynchronous mode.
- During transmission, at least 2 etu (elementary time unit: time required for transferring 1 bit) is secured as a guard time from the end of the parity bit until the start of the next frame.
- If a parity error is detected during reception, a low-level error signal is output for 1 etu after 10.5 etu has passed from the start bit.
- If an error signal is sampled during transmission, the same data is automatically retransmitted after at least 2 etu.



Figure 23.32 Data Formats in Smart Card Interface Mode

For communications with IC cards of the direct convention type and inverse convention type, follow the procedure below.

#### (1) Direct Convention Type

For the direct convention type, logic levels 1 and 0 correspond to states Z and A, respectively, and data is transferred with LSB first as the start character, as shown in Figure 23.33. Therefore, data in the start character in the figure is 3Bh. When using the direct convention type, write 0 to both the SDIR and SINV bits in the SCMR register. Write 0 to the PM bit in the SMR register in order to use even parity, which is prescribed by the smart card standard.



Figure 23.33 Direct Convention (SDIR in SCMR = 0, SINV in SCMR = 0, PM in SMR = 0)

#### (2) Inverse Convention Type

For the inverse convention type, logic levels 1 and 0 correspond to states A and Z, respectively and data is transferred with MSB first as the start character, as shown in Figure 23.34. Therefore, data in the start character in the figure is 3Fh. When using the inverse convention type, write 1 to both the SDIR and SINV bits in the SCMR register. The parity bit is logic level 0 to produce even parity, which is prescribed by the smart card standard, and corresponds to state Z. Since the SINV bit of the this MCU only inverts data bits D7 to D0, write 1 to the PM bit in the SMR register to invert the parity bit for both transmission and reception.



Figure 23.34 Inverse Convention (SDIR in SCMR = 1, SINV in SCMR = 1, PM in SMR = 1)

#### 23.6.3 Block Transfer Mode

Block transfer mode is different from normal smart card interface mode in the following respects.

- Even if a parity error is detected during reception, no error signal is output. Since the PER bit in the SSR register is set by error detection, clear the PER bit before receiving the parity bit of the next frame.
- During transmission, at least 1 etu is secured as a guard time from the end of the parity bit until the start of the next frame.
- Since the same data is not retransmitted during transmission, the TEND flag in the SSR register is set 11.5 etu after transmission start.
- In block transfer mode, the ERS flag in the SSR register indicates the error signal status as in normal smart card interface mode, but the flag is read as 0 because no error signal is transferred.

# 23.6.4 Receive Data Sampling Timing and Reception Margin

Only the internal clock generated by the on-chip baud rate generator can be used as a transfer clock in smart card interface mode.

In this mode, the SCI can operate on a base clock with a frequency of 32, 64, 372, 256, 93, 128, 186, or 512 times the bit rate according to the settings of the BCP2 bit in the SCMR register and the BCP[1:0] bits in the SMR register (the frequency is always 16 times the bit rate in normal asynchronous mode).

For data reception, the falling edge of the start bit is sampled with the base clock to perform internal synchronization. Receive data is sampled on the 16th, 32nd, 186th, 128th, 46th, 64th, 93rd, and 256th rising edges of the base clock so that it can be latched at the middle of each bit as shown in Figure 23.35. The reception margin here is determined by the following formula.

$$M = \left| \begin{array}{c|c} (0.5 - \frac{1}{2N}) - (L - 0.5) & F - \frac{D - 0.5}{N} \end{array} \right| (1 + F) \times 100 \, [\%]$$

M: Reception margin (%)

N: Ratio of bit rate to clock (N = 32, 64, 372, 256)

D: Duty cycle of clock (D = 0 to 1.0)

L: Frame length (L = 10)

F: Absolute value of clock frequency deviation

Assuming values of F = 0, D = 0.5, and N = 372 in the above formula, the reception margin is determined by the formula below.

$$M = \{0.5 - 1/(2 \times 372)\} \times 100 [\%] = 49.866\%$$



Figure 23.35 Receive Data Sampling Timing in Smart Card Interface Mode (When Clock Frequency is 372 Times the Bit Rate)

# 23.6.5 SCI Initialization (Smart Card Interface Mode)

Initialize the SCI following the example of flowchart shown in Figure 23.36.

Be sure to initialize the SCI before switching from transmission mode to reception mode and vice versa. Even if the RE bit is set to 0, the RDR register is not initialized.

To change reception mode to transmission mode, first check that reception has completed, and then initialize the SCI. At the end of initialization, set TE = 1 and RE = 0. Reception completion can be verified by reading the RXI request, ORER, or PER flag in the SSR register.

To change transmission mode to reception mode, first check that transmission has completed, and then initialize the SCI. At the end of initialization, set TE = 0 and RE = 1. Transmission completion can be verified by reading the TEND flag in the SSR register.



Figure 23.36 Example of SCI Initialization Flowchart (Smart Card Interface Mode)

# 23.6.6 Serial Data Transmission (Except in Block Transfer Mode)

Serial data transmission in smart card interface mode (except in block transfer mode), in that an error signal is sampled and data can be retransmitted, is different from that in non-smart card interface mode. Figure 23.37 shows the data retransfer operation during transmission.

- 1. When an error signal from the receiver end is sampled after one-frame data has been transmitted, the ERS flag in the SSR register is set to 1. If the RIE bit in the SCR register is 1 at this time, an ERI interrupt request is generated. Clear the ERS flag to 0 before the next parity bit is sampled.
- 2. For a frame in which an error signal is received, the TEND flag in the SSR register is not set. Data is retransferred from the TDR register to the TSR register allowing automatic data retransmission.
- 3. If no error signal is returned from the receiver, the ERS flag is not set to 1.
- 4. In this case, the SCI judges that transmission of one-frame data (including retransfer) has been completed, and the TEND flag is set. If the TIE bit in the SCR register is 1 at this time, a TXI interrupt request is generated. Writing transmit data to the TDR register starts transmission of the next data.

Figure 23.39 shows a sample flowchart of serial transmission. All the processing steps are automatically performed using a TXI interrupt request to activate the DTC.

When the TEND flag in the SSR register is set to 1 in transmission, if the TIE bit in the SCR register is 1, a TXI interrupt request is generated. The DTC is activated by a TXI interrupt request if the TXI interrupt request is specified as a source of DTC activation beforehand, allowing transfer of transmit data. The TEND flag is automatically set to 0 when the DTC transfers the data.

If an error occurs, the SCI automatically retransmits the same data. During this retransmission, the TEND flag is kept to 0 and the DTC is not activated. Therefore, the SCI and DTC automatically transmit the specified number of bytes, including retransmission in the case of error occurrence. However, since the ERS flag is not automatically cleared, set the RIE bit to 1 beforehand to enable an ERI interrupt request to be generated at error occurrence, and clear the ERS flag to 0

When transmitting/receiving data using the DTC, be sure to make settings to enable the DTC before making SCI settings. For DTC settings, refer to section 16, Data Transfer Controller (DTCa).



Figure 23.37 Data Retransfer Operation in SCI Transmission Mode

Note that the SSR.TEND flag is set in different timings depending on the GM bit setting in the SMR register. Figure 23.38 shows the TEND flag generation timing.



Figure 23.38 SSR.TEND Flag Generation Timing during Transmission



Figure 23.39 Sample Smart Card Interface Transmission Flowchart

# 23.6.7 Serial Data Reception (Except in Block Transfer Mode)

Serial data reception in smart card interface mode is similar to that in non-smart card interface mode. Figure 23.40 shows the data retransfer operation in reception mode.

- 1. If a parity error is detected in receive data, the PER flag in the SSR register is set to 1. When the RIE bit in the SCR register is 1 at this time, an ERI interrupt request is generated. Clear the PER flag to 0 before the next parity bit is sampled.
- 2. For a frame in which a parity error is detected, no RXI interrupt is generated.
- 3. When no parity error is detected, the PER flag in the SSR register is not set to 1.
- 4. In this case, data is determined to have been received successfully. When the RIE bit in the SCR register is 1, an RXI interrupt request is generated.

Figure 23.41 shows a sample flowchart for serial data reception. All the processing steps are automatically performed using an RXI interrupt request to activate the DTC.

In reception, setting the RIE bit to 1 allows an RXI interrupt request to be generated. The DTC is activated by an RXI interrupt request if the RXI interrupt request is specified as a source of DTC activation beforehand, allowing transfer of receive data.

If an error occurs during reception and either the ORER or PER flag in the SSR register is set to 1, a receive error interrupt (ERI) request is generated. Clear the error flag after the error occurrence. If an error occurs, the DTC is not activated and receive data is skipped. Therefore, the number of bytes of receive data specified in the DTC is transferred. Even if a parity error occurs and the PER flag is set to 1 during reception, receive data is transferred to RDR, thus allowing the data to be read.

Note 1. For operations in block transfer mode, refer to section 23.3, Operation in Asynchronous Mode.



Figure 23.40 Data Retransfer Operation in SCI Reception Mode (Data Retransfer Operation during Reception)



Figure 23.41 Sample Smart Card Interface Reception Flowchart

#### 23.6.8 Clock Output Control

Clock output can be fixed using the CKE[1:0] bits in the SCR register when the GM bit in the SMR register is 1. Specifically, the minimum width of a clock pulse can be specified.

Figure 23.42 shows an example of clock output fixing timing when the CKE[0] bit is controlled with GM = 1 and CKE[1] = 0.



Figure 23.42 Clock Output Fixing Timing

To secure the appropriate clock duty cycle simultaneously with power-on, use the following procedure.

- 1. Initially, port input is enabled in the high-impedance state. To fix the potential level, use a pull-up or pull-down resistor.
- 2. Fix the SCKn pin to the specified output by setting the SCR.CKE[1] bit and I/O port functions.
- 3. Set SMR and SCMR to enable smart card interface mode.
- 4. Set the SCR.CKE[0] bit to 1 to start clock output.

# 23.7 Operation in Simple I<sup>2</sup>C Mode

Simple I<sup>2</sup>C-bus format is composed of 8 data bits and an acknowledge bit. By continuing into a slave-address frame after a start condition or restart condition, a master device is able to specify a slave device as the partner for communications. The currently specified slave device remains valid until a new slave device is specified or a stop condition is satisfied. The 8 data bits in all frames are transmitted in order from the MSB.

The I<sup>2</sup>C format and timing of the I<sup>2</sup>C-bus are shown in Figure 23.43 and Figure 23.44.



Figure 23.43 I<sup>2</sup>C-bus Format



Figure 23.44 I<sup>2</sup>C-bus Timing (When SLA is 7 Bits)

- S: Indicates a start condition, i.e. the master device changing the level on the SSDAn line from the high to the low level while the SSCLn line is at the high level.
- SLA: Indicates a slave address, by which the master device selects a slave device.
- R/W#: Indicates the direction of transfer (reception or transmission). The value 1 corresponds to transfer from the slave device to the master device and 0 corresponds to transfer from the master device to the slave device.
- A/A#: Indicates an acknowledge bit. This is returned by the slave device for master transmission and by the master device for master reception. Return of the low level indicates ACK and return of the high level indicates NACK.
- Sr: Indicates a restart condition, i.e. the master device changing the level on the SSDAn line from the high to the low level while the SSCLn line is at the high level and after the setup time has elapsed.
- DATA: Indicates the data being received or transmitted.
- P: Indicates a stop condition, i.e. the master device changing the level on the SSDAn line from the low to the high level while the SSCLn line is at the high level.

#### 23.7.1 Generation of Start, Restart, and Stop Conditions

Writing 1 to the IICSTAREQ bit in the SIMR3 register causes the generation of a start condition. The generation of a start condition proceeds through the following operations.

- The level on the SSDAn line falls (from the high level to the low level) and the SSCLn line is kept in the released state
- The hold time for the start condition is secured as half of a bit period at the bit rate determined by the setting of the BRR.
- The level on the SSCLn line falls (from the high level to the low level), the IICSTAREQ bit in the SIMR3 register is set (to 0), and a start-condition generated interrupt is output.

Writing 1 to the IICRSTAREQ bit in the SIMR3 register causes the generation of a start condition. The generation of a start condition proceeds through the following operations.

- The SSDAn line is released and the SSCLn line is kept at the low level.
- The period at low level for the SSCLn line is secured as half of a bit period at the bit rate determined by the setting of the BRR.
- The SSCLn line is released (transition from the low to the high level).
- Once the high level on the SSCLn line is detected, the setup time for the restart condition is secured as half of a bit period at the bit rate determined by the setting of the BRR.
- The level on the SSDAn line falls (from the high level to the low level).
- The hold time for the restart condition is secured as half of a bit period at the bit rate determined by the setting of the BRR.
- The level on the SSCLn line falls (from the high level to the low level), the IICRSTAREQ bit in the SIMR3 register is set (to 0), and a restart-condition generated interrupt is output.

Writing 1 to the IICSTPREQ bit in the SIMR3 register causes the generation of a stop condition. The generation of a stop condition proceeds through the following operations.

- The level on the SSDAn line falls (from the high level to the low level) and the SSCLn line is kept at the low level.
- The period at low level for the SSCLn line is secured as half of a bit period at the bit rate determined by the setting of the BRR.
- The SSCLn line is released (transition from the low to the high level).
- Once the high level on the SSCLn line is detected, the setup time for the stop condition is secured as half of a bit period at the bit rate determined by the setting of the BRR.
- The SSDAn is released (transition from the low to the high level), the IICSTPREQ bit in the SIMR3 register is set (to 0), and a stop-condition generated interrupt is output.

Figure 23.45 shows the timing of operations in the generation of start, restart, and stop conditions.



Figure 23.45 Timing of Operations in the Generation of Start, Restart, and Stop Conditions

#### 23.7.2 Clock Synchronization

The SSCLn line may be placed at the low level in the case of a wait inserted by a slave device as the other side of transfer. Setting the IICCSC bit in the SIMR2 register to 1 applies control to obtain synchronization when the levels of the internal SSCLn clock signal and the level being input on the SSCLn pin differ.

When the IICCSC bit in the SIMR2 register is set to 1, the level of the internal SSCLn clock signal changes from low to high, counting to determine the period at high level is stopped while the low level is being input on the SSCLn pin, and counting to determine the period at high level starts after the transition of the input on the SSCLn pin to the high level. The interval from this time until counting to determine the period at high level starts on the transition of the SSCLn pin to the high level is the total of the delay of SSCLn output, delay for noise filtering of the input on the SSCLn pin (2 or 3 cycles of sampling clock for the noise filter), and delay for internal processing (1 or 2 cycles of PCLK). The period at high level of the internal SSCLn clock is extended even if other devices are not placing the low level on the SSCLn line. If the IICCSC bit in the SIMR2 register is 1, synchronization is obtained for the transmission and reception of data by taking the logical AND of the input on the SSCLn pin and the internal SSCLn clock. If the IICCSC bit in the SIMR2 register is 0, synchronization with the internal SSCLn clock is obtained for the transmission and reception of data. If a slave device inserts a period of waiting into the interval until the transition of the internal SSCLn clock signal from the low to the high level after a request for the generation of a start, restart, or stop condition is issued, the time until generation is prolonged by that period.

If a slave device inserts a period of waiting after the transition of the internal SSCLn clock signal from the low to the high level, although the generation-completed interrupt is issued without stopping the period of waiting, generation of the condition itself is not guaranteed. Figure 23.46 shows an example of operations to synchronize the clocks.



Figure 23.46 Example of Operations for Clock Synchronization

# 23.7.3 SSDA Output Delay

The IICDL[4:0] bits in the SIMR1 register can be used to set a delay for output on the SSDAn pin relative to falling edges of output on the SSCLn pin. Delay-time settings from 0 to 31 are selectable, representing periods of the corresponding numbers of cycles of the clock signal from the on-chip baud rate generator (derived by frequency-dividing the base clock, PCLK, by the divisor selected by the CKS[1:0] bits in the SMR register). A delay for output on the SSDAn pin is for the start condition/restart condition/stop condition signal, 8-bit transmit data, and an acknowledge bit. If the SSDA output delay is shorter than the time for the level on the SSCLn pin to fall, the change of the output on the SSDAn pin will start while the output level on the SSCLn pin is falling, creating a possibility of erroneous operation for slave devices. Ensure that settings for the delay of output on the SSDAn pin are for times greater than the time output on the SSCLn pin takes to fall (300 ns for I<sup>2</sup>C in normal mode and fast mode).

Figure 23.47 shows the timing of delays in SSDA output.



Figure 23.47 Timing of Delays in SSDA Output

# 23.7.4 SCI Initialization (Simple I<sup>2</sup>C Mode)

Before transferring data, write the initial value (00h) to SCR and initialize the interface following the example shown in Figure 23.48.

When changing the operating mode, transfer format, and so on, be sure to set SCR to its initial value before proceeding with the changes.

In simple I<sup>2</sup>C mode, the open-drain setting for the communication ports should be made on the port side.



Figure 23.48 Example of the Flowchart of SCI Initialization (for Simple I<sup>2</sup>C Mode)

# 23.7.5 Operation in Master Transmission (Simple I<sup>2</sup>C Mode)

Figure 23.49 and Figure 23.50 show examples of operations in master transmission and Figure 23.51 is a flowchart showing the procedure for data transmission. Refer to Table 23.32 for more information on the STI interrupt. When 10-bit slave addresses are in use, steps [3] and [4] in Figure 23.51 are repeated twice.

In simple I<sup>2</sup>C mode, the transmit data empty interrupt (TXI) is generated when communication of one frame is completed, unlike the TXI interrupt request generation timing during clock synchronous transmission.



Figure 23.49 Example 1 of Operations for Master Transmission in Simple I<sup>2</sup>C-bus Mode (with 7-Bit Slave Addresses, Transmission Interrupts, and Reception Interrupts in Use)

When the SIMR2.IICINTM bit is set to 0 (use ACK/NACK interrupts) during master transmission, the DTC is activated by the ACK interrupt as the trigger and necessary number of data bytes are transmitted. When the NACK is received, error processing, such as transmission stop and retransmission, is performed by the NACK interrupt as the trigger.



Figure 23.50 Example 2 of Operations for Master Transmission in Simple I<sup>2</sup>C-bus Mode (with 7-Bit Slave Addresses, ACK Interrupts, and NACK Interrupts in Use)



Figure 23.51 Example of the Procedure for Master Transmission Operations in Simple I<sup>2</sup>C Mode (with Transmission Interrupts and Reception Interrupts in Use)

# 23.7.6 Master Reception (Simple I<sup>2</sup>C Mode)

Figure 23.52 shows an example of operations in simple I<sup>2</sup>C mode master reception and Figure 23.53 is a flowchart showing the procedure for master reception.

The value of the SIMR2.IICINTM bit is assumed to be 1 (use reception and transmission interrupts).

In simple I<sup>2</sup>C mode, the transmit data empty interrupt (TXI) is generated when communication of one frame is completed, unlike the TXI interrupt request generation timing during clock synchronous transmission.



Figure 23.52 Example of Operations for Master Reception in Simple I<sup>2</sup>C-bus Mode (with 7-Bit Slave Addresses, Transmission Interrupts, and Reception Interrupts in Use)



Figure 23.53 Example of the Procedure for Master Reception Operations in Simple I<sup>2</sup>C Mode (with Transmission Interrupts and Reception Interrupts in Use)

### 23.8 Operation in Simple SPI Mode

As an extended function, the SCI supports a simple SPI mode that handles transfer among one or multiple master devices and multiple slave devices.

Making the settings for clock synchronous mode (SCMR.SMIF = 0, SIMR1.IICM = 0, SMR.CM = 1) plus setting the SSE bit in the SPMR to 1 places the SCI in simple SPI mode. However, the SS pin function on the master side is unnecessary for connection of the device used as the master in simple SPI mode when the configuration only has a single master, so set the SSE bit in the SPMR to 0 in such cases.

Figure 23.54 shows an example of connections for simple SPI mode. Control a general port pin to produce the SS output signal from the master.

In simple SPI mode, data are transferred in synchronization with clock pulses in the same way as in clock synchronous mode. One character of data for transfer consists of 8 bits of data, and parity bits cannot be appended to this. The data can be inverted by setting the SCMR.SINV bit to 1.

Since the receiver and transmitter are independent of each other within the SCI module, full-duplex communications are possible, with a common clock signal. Furthermore, since both the transmitter and receiver have a double-buffered structure, writing of further transmit data while transmission is in progress and reading of previously received data while reception is in progress are both possible. Continuous transfer is thus possible.



Figure 23.54 Example of Connections via a Simple SPI Mode (In Single Master Mode, SPMR.SSE Bit = 0)

#### 23.8.1 States of Pins in Master and Slave Modes

The direction (input or output) of pins for the simple SPI mode interface differs according to whether the device is a master (SCR.CKE[1:0] = 00b or 01b and SPMR.MSS = 0) or slave (SCR.CKE[1:0] = 10b or 11b and SPMR.MSS = 1). Table 23.28 lists the states of pins according to the mode and the level on the SSn# pin.

Table 23.28 States of Pins by Mode and Input Level on the SSn# Pin

| Mode          | Input on SSn# Pin                   | State of SMOSIn Pin                    | State of SMISOn Pin                    | State of SCKn Pin             |
|---------------|-------------------------------------|----------------------------------------|----------------------------------------|-------------------------------|
| Master mode*1 | High level (transfer can proceed)   | Output for data transmission*2         | Input for received data                | Clock output*3                |
|               | Low level (transfer cannot proceed) | High-impedance                         | Input for received data (but disabled) | High-impedance                |
| Slave mode    | High level (transfer can proceed)   | Input for received data (but disabled) | High-impedance                         | Clock input<br>(but disabled) |
|               | Low level (transfer cannot proceed) | Input for received data                | Output for data transmission           | Clock input                   |

Note 1. When there is only a single master (SPMR.SSE = 0), transfer is possible regardless of the input level on the SSn# pin (this is equivalent to input of a high level on the SSn# pin). Since the SSn# pin function is not required, the pin is available for other purposes.

#### 23.8.2 SS Function in Master Mode

Setting the CKE[1:0] bits in the SCR to 00b and the MSS bit in the SPMR to 0 selects master operation. The SSn# pin is not used in single-master configurations (SPMR.SSE = 0), so transmission or reception can proceed regardless of the value of the SSn# pin.

When the level on the SSn# pin is high in a multi-master configuration (SPMR.SSE = 1), a master device outputs clock signals from the SCKn pin before starting transmission or reception to indicate that there are no other masters or another master is performing reception or transmission. When the level on the SSn# pin is low in a multi-master configuration (SPMR.SSE = 1), there are other masters, and this indicates that transmission or reception is in progress. At this time the SMOSIn output and SCKn pins will be placed in the high-impedance state and starting transmission or reception will not be possible. Furthermore, the value of the SPMR.MFF bit will be 1, indicating a mode fault error. In a multi-master configuration, start error processing by reading SPMR.MFF flag. Also, even if a mode fault error occurs while transmission or reception is in progress, transmission or reception will not be stopped, but the SMOSIn and SCKn pin output will be placed in the high-impedance state after the completion of the transfer.

Control a general port pin to produce the SS output signal from the master.

## 23.8.3 SS Function in Slave Mode

Setting the CKE[1:0] bits in the SCR to 10b and the MSS bit in the SPMR to 1 selects slave operation. When the level on the SSn# pin is high, the SMISOn output pin will be in the high-impedance state and clock input through the SCKn pin will be ignored. When the level on the SSn# pin is low, clock input through the SCKn pin will be effective and transmission or reception can proceed.

If the input on the SSn# pin changes from low to high level during transmission or reception, the SMISOn output pin will be placed in the high-impedance state. Meanwhile, the internal processing for transmission or reception will continue at the rate of the clock input through the SCKn pin until processing for the character currently being transmitted or received is completed, after which it stops. At that time, an interrupt (the appropriate one from among TXI, RXI, and TEI) will be generated.



Note 2. The SMOSIn pin output is in the high-impedance state when serial transmission is disabled (SCR.TE bit = 0).

Note 3. The SCKn pin output is in the high-impedance state when serial transmission is disabled (SCR.TE and RE bits = 00b) in a multimaster configuration (SPMR.SSE = 1).

## 23.8.4 Relationship between Clock and Transmit/Receive Data

The CKPOL and CKPH bits in the SPMR can be used to set up the clock for use in transmission and reception in four different ways. The relation between the clock signal and the transmission and reception of data is shown in Figure 23.55. The relation is the same for both master and slave operation.



Figure 23.55 Relation between Clock Signal and Transmit/Receive Data in Simple SPI Mode

## 23.8.5 SCI Initialization (Simple SPI Mode)

The procedure is the same as for initialization in clock synchronous mode Figure 23.22, Sample SCI Initialization Flowchart. The CKPOL and CKPH bits in the SPMR must be set to ensure that the kind of clock signal they select is suitable for both master and slave devices.

For initialization, changes to the operating mode, changes to the transfer format, and so on, initialize the SCR register before proceeding with changes.

As well as setting the RE bit to 0, note that the SSR.ORER, FER, and PER flags, as well as the RDR, are not initialized. Note that changing the value of the TE bit from 1 to 0 or from 0 to 1 will lead to the generation of a transmit data empty interrupt (TXI) if the value of the TIE bit in the SCR is 1 at the time.

## 23.8.6 Transmission and Reception of Serial Data (Simple SPI Mode)

In master operation, ensure that the SSn# pin of the slave device on the other side of the transfer is at the low level before starting the transfer and at the high level on completion of the transfer. Otherwise, the procedures are the same as in clock synchronous mode.

# 23.9 Extended Serial Mode Control Section: Description of Operation

# 23.9.1 Serial Transfer Protocol

In conjunction with the SCIe module, the extended serial mode control section of the SCIf module can realize the serial transfer protocol composed of Start Frames and Information Frames that is shown in Figure 23.56.

A Start Frame is composed of a Break Field, Control Field 0, and Control Field 1. An Information Frame is composed of a number of Data Fields, a CRC16 Upper Field, and a CRC16 Lower Field.



Figure 23.56 Protocol for Serial Transfer by the Extended Serial Mode Control Section

## 23.9.2 Transmitting a Start Frame

Figure 23.57 shows an example of operations to transmit a Start Frame, which is composed of the Break Field low width, Control Field 0, and Control Field 1. Figure 23.58 and Figure 23.59 are flowcharts for the transmission of a Start Frame.

Operations when the extended serial mode control section is to be used to transmit a Start Frame are as listed below. Be sure to use the SCI12 in asynchronous mode.

- (1) With Break Field low width output mode as the operating mode for the timer, writing 1 to the TCR.TCST bit starts counting by the timer, and the low level will be output from the TXDX12 pin over the period corresponding to registers TCNT and TPRE settings.
- (2) The output on the TXDX12 pin is inverted when the timer counter underflows, and the STR.BFDF flag is set to 1. An SCIX0 interrupt is also generated if the value of the ICR.BFDIE bit is 1.
- (3) Write 0 to the TCR.TCST bit to stop counting by the timer, and send the data for Control Field 0 by using SCI12. After the Break Field low width output, stop counting before the next underflow occurs.
- (4) When the data for Control Field 0 have been transmitted, send the data for Control Field 1.
- (5) When the data for Control Field 1 have been transmitted, send an Information Frame.

Omit the Break Field and Control Field 0 to suit the structure of the Start Frame.



Figure 23.57 Example of Operations When Transmitting a Start Frame



Figure 23.58 Example of Start Frame Transmission (1/2)



Figure 23.59 Example of Start Frame Transmission (2/2)

## 23.9.3 Receiving a Start Frame

The extended serial mode control section is capable of receiving Start Frames with the structures listed in Table 23.29.

Table 23.29 Structures of Start Frames



Figure 23.60 shows an example of operations to receive a Start Frame, which is composed of the Break Field low width, Control Field 0, and Control Field 1. Figure 23.61 and Figure 23.62 are flowcharts for the reception of a Start Frame, and Figure 23.63 is a state transition diagram for the extended serial mode control section.

Operations when the extended serial mode control section is to be used to receive a Start Frame are as listed below. Be sure to use the SCI12 in asynchronous mode.

- (1) With Break Field low width detection mode as the operating mode for the timer, writing 1 to the CR3.SDST bit enables detection of the Break Field low width. RXDX12 input to the SCI12 is disabled at this time.
- (2) Low-level input on the RXDX12 pin continuing over a period longer than that corresponding to the settings of registers TCNT and TPRE is detected as the Break Field low width. At this time, the STR.BFDF flag is set to 1. An SCIX0 interrupt is also generated if the value of the ICR.BFDIE bit is 1.
- (3) When the input from the RXDX12 pin goes high after the Break Field low width, the CR0.RXDSF flag becomes 0 and reception of Control Field 0 by the SCI12 starts.
- (4) If the data received in Control Field 0 match the data set in the CF0DR register, the STR.CF0MF flag is set to 1. An SCIX1 interrupt is also generated if the value of the ICR.CF0MIE bit is 1. Reception of Control Field 1 by the SCI12 starts after that. If the data received in Control Field 0 do not match the data set in the CF0DR register, a transition to the state prior to Break Field low width detection proceeds.
- (5) If the data received in Control Field 1 match the data set in registers PCF1DR and SCF1DR, the STR.CF1MF flag is set to 1. An SCIX1 interrupt is also generated if the value of the ICR.CF1MIE bit is 1. Transfer of the Information Frame by the SCI12 starts after that. If the data received in Control Field 1 do not match the data set in either or both of registers PCF1DR and SCF1DR, a transition to the state prior to Break Field low width detection proceeds.

Omit the Break Field and Control Field 0 to suit the structure of the Start Frame.



Figure 23.60 Example of Operations at the Time of Start Frame Reception



Figure 23.61 Sample Flowchart for Reception of a Start Frame (1)



Figure 23.62 Sample Flowchart for Reception of a Start Frame (2)



Figure 23.63 State Transitions When Receiving a Start Frame

## 23.9.3.1 Priority Interrupt Bit

Figure 23.64 shows an example of operation in Start Frame reception where a priority interrupt bit is in use. Setting the CR1.PIBE bit to 1 enables the use of a priority interrupt bit.

Operations of the extended serial mode control section in start Frame reception where a priority interrupt bit is in use are as described below.

Steps (1) to (4) are the same as in Figure 23.60, for Start Frame reception.

(5) If the value of the bit selected by the CR1.PIBS[2:0] bits matches the corresponding bit in the PCF1DR register, the STR.PIBDF flag is set to 1. An SCIX1 interrupt is also generated if the value of the ICR.PIBDIE bit is 1. Transfer of the Information Frame by the SCI12 starts after that. If the data received in Control Field 1 do not match the data set in either or both of registers PCF1DR and SCF1DR and the priority interrupt bit is not detected, a transition to the state prior to Break Field low width detection proceeds.



Figure 23.64 Example of Operations When Receiving a Start Frame While the CR1.PIBE Bit is 1

#### 23.9.4 Detection of Bus Collisions

Detection of bus collisions operate for cases where output of the Break Field low width and transmission of data by the SCI12 are in progress when the ESMER.ESME bit and the SCI12.SCI.TE bit are set to 1.

Figure 23.65 shows an example of operations with bus collision detection. Signals output through TXDX12 and input through RXDX12 are sampled with the bus collision detection clock set with the CR2.BCCS[1:0] bits as the sampling clock, and the STR.BCDF flag is set to 1 if the signals fail to match three times in a row. An SCIX2 interrupt is also generated if the value of the ICR.BCDIE bit is 1.



Figure 23.65 Example of Operations with Bus Collision Detection

# 23.9.5 Digital Filter for Input on the RXDX12 Pin

Signals input through the RXDX12 pin can be passed through a digital filter before they are conveyed to the internal circuits. The digital filter consists of three flip-flop circuit stages connected in series and a match-detecting circuit. The CR2.DFCS[2:0] bits select the sampling clock for the RXDX12 pin input signals. If the outputs of all three latches match, the given level is conveyed to subsequent circuits. If the levels do not match, the previous value is retained. In other words, levels are confirmed as being the signal if they are retained for at least three cycles of the sampling clock but judged to be noise rather than changes in the signal level if they change within three cycles of the sampling clock. Figure 23.66 shows an example of operations with the digital filter.



Figure 23.66 Example of Operations with the Digital Filter

#### 23.9.6 Bit Rate Measurement

The bit rate measurement function measures the intervals between rising and falling edges and between falling and rising edges of the signal input from the RXDX12 pin. Figure 23.67 shows an example of operations for bit rate measurement.

- (1) Writing 1 to the CR0.BRME bit enables bit rate measurement. Only set the BRME bit to 1 when you wish to proceed with bit rate measurement. Furthermore, bit rate measurement will not proceed during a Break Field, even if the BRME bit is set to 1.
- (2) After detection of the Break Field low width, bit rate measurement starts when the level input on the RXDX12 pin becomes high.
- (3) Once bit rate measurement has started, counter values from the timer are retained in the read buffers on the input of valid edges from the RXDX12 pin (rising and falling edges) and the counter is reloaded. An SCIX3 interrupt is also generated if the value of the ICR.AEDIE bit is 1. Retention by registers TCNT and TPRE is released by reading these registers.
- (4) The bit rate as calculated from the values counted during intervals between valid edges can be used for adjusting the rate by changing the settings of the SCI12. To disable the bit rate measurement after a match with Control Field 1, write 0 to the CR0.BRME bit.



Figure 23.67 Example of Operations for Bit Rate Measurement

# 23.9.7 Selectable Timing for Sampling Data Received through RXDX12

The extended serial mode control section provides a way of adjusting the timing for the sampling of data received through the RXDX12 pin of an SCI12 by setting the CR2.RTS[1:0] bits to select the rising edges of 8th, 10th, 12th, or 14th cycle of the SCI base clock. If the value of the SEMR.ABCS bit is 1, the bits select the rising edges of 4th, 5th, 6th, or 7th cycle of the PCLK clock of the SCI12. Figure 23.68 shows timing for the sampling of data received through RXDX12.



Figure 23.68 Timing for Sampling of Data Received through RXDX12

#### 23.9.8 Timer

The timer has the following operating modes.

## (1) Break Field Low Width Output Mode

This mode is for output through the TXDX12 pin of the low level over the Break Field low width at the transmission of a Start Frame. Setting the TMR.TOMS[1:0] bits to 10b switches operation to Break Field low width output mode. The TMR.TCSS[2:0] bits select the clock source for the counter. When the TCR.TCST bit is set to 1, the output on the TXDX12 pin goes to the low level and counting starts. When the timer underflows, the output on the TXDX12 pin goes to the high level and the STR.BFDF flag is set to 1. An SCIX0 interrupt is also generated if the value of the ICR.BFDIE bit is 1. When 0 is written to the TCR.TCST bit, counting stops after reloading of registers TPRE and TCNT. After output of the Break Field low width is completed, stop the timer before it underflows again. Figure 23.69 shows an example of operations in Break Field low width output mode.



Figure 23.69 Example of Operations in Break Field Low Width Output Mode

#### (2) Break Field Low Width Determination Mode

This mode is for determining the Break Field low width in the input signal on the RXDX12 pin at the reception of a Start Frame. Setting the TMR.TOMS[1:0] bits to 01b switches operation to Break Field low width determination mode. The TMR.TCSS[2:0] bits select the clock source for the counter. When the TCR.TCST bit is set to 1, the interface enters the Break Field low width determinable state. Determination starts when a low level is input from the RXDX12 pin. When a high level is then input on the RXDX12 pin, registers TPRE and TCNT are reloaded and the interface enters the Break Field low width determinable state. When the timer underflows during Break Field low width determination, the STR.BFDF flag is set to 1. An SCIX0 interrupt is also generated if the value of the ICR.BFDIE bit is 1. If an underflow of the timer during data transfer cause a problem in the form of interrupt generation, stop the timer after Break Field low width determination. Figure 23.70 shows an example of operations in Break Field low width output mode.



Figure 23.70 Example of Operations in Break Field Low Width Determination Mode

## (3) Timer Mode

This mode is for counting cycles of the internal clock as the clock source. Setting the TMR.TOMS[1:0] bits to 00b switches operation to timer mode. The TMR.TCSS[2:0] bits select the clock source for the counter. Counting starts when 1 is written to the TCR.TCST bit and stops when 0 is written to the TCST bit. Registers TPRE and TCNT both count down. The TPRE register counts cycles of the clock source for counting, and underflows of the TPRE register provide the clock source for counting by the TCNT register. When the timer underflows, the STR.BFDF flag is set to 1. An SCIX0 interrupt is also generated if the value of the ICR.BFDIE bit is 1.

#### 23.10 Noise Cancellation Function

Figure 23.71 shows the configuration of the noise filter used for noise cancellation. The noise filter consists of two stages of flip-flop circuits and a match-detection circuit. When the level on the pin matches in three consecutive samples taken at the set sampling interval, the matching level continues to be conveyed internally until the level on the pin again matches in three consecutive samples.

In asynchronous mode, the noise cancellation function can be applied on the RXDn input signal. The period of the base clock (1/16th of a bit-period when SEMR.ABCS = 0 and 1/8th of a bit-period when SEMR.ABCS = 1) is the sampling interval.

In simple I<sup>2</sup>C mode, the noise cancellation function can be applied on the SSDAn and SSCLn input signals. The sampling clock is the clock signal produced by frequency-dividing the signal from the clock source for the internal baudrate generator by one, two, four, or eight as selected by the setting of the SNFR.NFCS[2:0] bits.

If the base clock is stopped with the noise filter enabled and then the clock input is started again, the noise filter operation resumes from where the clock was stopped. If SCR.TE and SCR.RE are set to 0 during base clock input, all of the noise filter flip-flop values are initialized to 1. Accordingly, if the input data is 1 when reception operation resumes, it is determined that a level match is detected and is conveyed to the internal signal. When the level being input corresponds to 0, the initial output of the noise filter is retained until the level matches in three consecutive samples.



Figure 23.71 Block Diagram of Digital Noise Filter Circuit

### 23.11 Interrupt Sources

## 23.11.1 Buffer Operations for TXI and RXI Interrupts

If the conditions for a TXI and RXI interrupt are satisfied while the interrupt status flag in the interrupt controller is 1, the SCI does not output the interrupt request but retains it internally (with a capacity for retention of one request per source). When the value of the interrupt status flag in the interrupt controller becomes 0, the interrupt request retained within the SCI is output. The internally retained interrupt request is automatically discarded once the actual interrupt is output. Clearing of the corresponding interrupt enable bit (the TIE or RIE bit in the SCR) can also be used to discard an internally retained interrupt request.

# 23.11.2 Interrupts in Asynchronous Mode, Clock Synchronous Mode, and Simple SPI Mode

Table 23.30 lists interrupt sources in asynchronous mode, clock synchronous mode, and simple SPI mode. A different interrupt vector is assigned to each interrupt source, and individual interrupt sources can be enabled or disabled with the enable bits in the SCR register.

If the SCR.TIE bit is 1, a TXI interrupt request is generated when transmit data is transferred from the TDR to the TSR. A TXI interrupt request can also be generated by setting the SCR.TE bit to 1 after setting the SCR.TIE bit to 1 or by using a single instruction to set the SCR.TE and SCR.TIE bit to 1 at the same time. A TXI interrupt request can activate the DTC to handle data transfer.

A TXI interrupt request is not generated by setting the SCR.TE bit to 1 while the setting of the SCR.TIE bit is 0 or by setting the SCR.TIE bit to 1 while the setting of the SCR.TE bit is  $1.*^{1}$ 

When new data is not written by the time of transmission of the last bit of the current transmit data and the setting of the SCR.TEIE bit is 1, the SSR.TEND flag becomes 1 and a TEI interrupt request is generated. Furthermore, when the setting of the SCR.TE bit is 1, the SSR.TEND flag retains the value 1 until further transmit data are written to the TDR, and setting the SCR.TEIE bit to 1 leads to the generation of a TEI interrupt request.

Writing data to the TDR leads to clearing of the SSR.TEND flag and, after a certain time, discarding of the TEI interrupt request.

If the SCR.RIE bit is 1, an RXI interrupt request is generated when received data is stored in the RDR. An RXI interrupt request can activate the DTC to handle data transfer.

Setting of any from among the ORER, FER, and PER flags in the SSR to 1 while the SCR.RIE bit is 1 leads to the generation of an ERI interrupt request. An RXI interrupt request is not generated at this time. Clearing all three flags (ORER, FER, and PER) leads to discarding of the ERI interrupt request.

Note 1. To temporarily disable TXI interrupts at the time of transmission of the last of the data and so on when you wish a new round of transmission to start after handling of the transmission-completed interrupt, control disabling and enabling of the interrupt by using the interrupt request enable bit in the interrupt controller rather than using the SCR.TIE bit. This can prevent the suppression of TXI interrupt requests in the transfer of new data.

Table 23.30 Interrupt Sources

| Name | Interrupt Source Interrupt Flag |                   | DTC Activation | Priority |
|------|---------------------------------|-------------------|----------------|----------|
| ERI  | Receive error                   | ORER, FER, or PER | Not possible   | High     |
| RXI  | Receive data full               | RDRF              | Possible       |          |
| TXI  | Transmit data empty             | TDRE              | Possible       |          |
| TEI  | Transmit end                    | TEND              | Not possible   | Low      |

## 23.11.3 Interrupts in Smart Card Interface Mode

Table 23.31 lists interrupt sources in smart card interface mode. A transmit end interrupt (TEI) request cannot be used in this mode.

Table 23.31 SCI Interrupt Sources

| Name | Interrupt Source                        | Interrupt Flag    | DTC Activation | Priority |
|------|-----------------------------------------|-------------------|----------------|----------|
| ERI  | Receive error or error signal detection | ORER, PER, or ERS | Not possible   | High     |
| RXI  | Receive data full                       | _                 | Possible       | <b>↑</b> |
| TXI  | Transmit data empty                     | TEND              | Possible       | Low      |

Data transmission/reception using the DTC is also possible in smart card interface mode, similar to in the normal SCI mode. In transmission, when the TEND flag in the SSR register is set to 1, a TXI interrupt request is generated. This TXI interrupt request activates the DTC allowing transfer of transmit data if the TXI request is specified beforehand as a source of DTC activation. The TEND flag is automatically set to 0 when the DTC transfers the data.

If an error occurs, the SCI automatically retransmits the same data. During the retransmission, the TEND flag is kept to 0 and the DTC is not activated. Therefore, the SCI and DTC automatically transmit the specified number of bytes, including retransmission in the case of error occurrence. However, the ERS flag in the SSR register is not automatically cleared to 0 at error occurrence. Therefore, the ERS flag must be cleared by previously setting the RIE bit in the SCR register to 1 to enable an ERI interrupt request to be generated at error occurrence.

When transmitting/receiving data using the DTC, be sure to make settings to enable the DTC before making SCI settings. For DTC settings, refer to section 16, Data Transfer Controller (DTCa).

In reception, an RXI interrupt request is generated when receive data is set to RDR. This RXI interrupt request activates the DTC allowing transfer of receive data if the RXI request is specified beforehand as a source of DTC activation. If an error occurs, the error flag is set. Therefore, the DTC is not activated and an ERI interrupt request is issued to the CPU instead; the error flag must be cleared.

# 23.11.4 Interrupts in Simple I<sup>2</sup>C Mode

The interrupt sources in simple I<sup>2</sup>C mode are listed in Table 23.32. The STI interrupt is allocated to the transmit end interrupt (TEI) request. The receive error interrupt (ERI) request cannot be used.

The DTC can also be used to handle transfer in simple I<sup>2</sup>C mode.

When the value of the IICINTM bit in the SIMR2 register is 1, an RXI request will be generated on the falling edge of the SSCLn signal for the eighth bit. If the RXI has been set up as an activating request for the DTC beforehand, the RXI request will activate the DTC to handle transfer of the received data. Furthermore, a TXI request is generated on the falling edge of the SSCLn signal for the ninth bit (acknowledge bit). If the TXI has been set up as an activating request for the DTC beforehand, the TXI request will activate the DTC to handle transfer of the transmit data.

When the value of the IICINTM bit in the SIMR2 register is 0, an RXI request (ACK detection) if the input on the SSDAn pin is at the low level or a TXI request (NACK detection) if the input on the SSDAn pin is at the high level will be generated on the rising edge of the SSCLn signal for the ninth bit (acknowledge bit). If the RXI has been set up as an activating request for the DTC beforehand, the RXI request will activate the DTC to handle transfer of the received data. Also, if the DTC is used for data transfer in reception or transmission, be sure to set up and enable the DTC before setting up the SCI.

When the IICSTAREQ, IICRSTAREQ, and IICSTPREQ bits in the SIMR3 register are used to generate a start condition, restart condition, or stop condition, the STI request is issued when generation is complete.

Table 23.32 SCI Interrupt Sources

| Name | Interrupt Source                                                |                 | Interrupt Flag | DTC Activation | Priority |
|------|-----------------------------------------------------------------|-----------------|----------------|----------------|----------|
|      | IICINTM bit = 0                                                 | IICINTM bit = 1 |                |                |          |
| RXI  | ACK detection                                                   | Reception       | _              | Possible       | High     |
| TXI  | NACK detection                                                  | Transmission    | _              | Possible*1     | 1 ↑      |
| STI  | Completion of generation of a start, restart, or stop condition |                 | IICSTIF        | Not possible   | Low      |

Note 1. Activation of the DTC is only possible when the SIMR2.IICINTM bit is 1 (use reception and transmission interrupts).

# 23.11.5 Interrupt Requests from the Extended Serial Mode Control Section

The extended serial mode control section has a total of six types of interrupt request for generating the SCIX0 interrupt (Break Field low width detected), SCIX1 interrupt (Control Field 0 match, Control Field 1 match, priority interrupt bit detected), SCIX2 interrupt (bus collision detected), and SCIX3 interrupt (valid edge detected). When any of the interrupt factors is generated, the corresponding status flag is set to 1. Details of all of the interrupt requests are listed in Table 23.33.

Table 23.33 Interrupt Sources of the Extended Serial Mode Control Section

| Interrupt Request Status Flag                     |       | Interrupt Factors                                                                                                                                                                                                                                                      |  |
|---------------------------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| SCIX0 interrupt (Break Field low width detected)  | BFDF  | <ul> <li>Detection of a Break Field low width longer than the interval corresponding to the timer setting</li> <li>Completion of the output of a Break Field low width over the interval corresponding to the timer setting</li> <li>Underflow of the timer</li> </ul> |  |
| SCIX1 interrupt (Control Field 0 match)           | CF0MF | The data received in Control Field 0 matching the value set in CF0DR                                                                                                                                                                                                   |  |
| SCIX1 interrupt (Control Field 1 match)           | CF1MF | The data received in Control Field 1 matching the value set in PCF1DR or SCF1DR                                                                                                                                                                                        |  |
| SCIX1 interrupt (priority interrupt bit detected) | PIBDF | The value of the bit specified as the priority interrupt bit matching the value set in PCF1DR                                                                                                                                                                          |  |
| SCIX2 interrupt (bus collision detected)          | BCDF  | The output level on the TXDX12 pin and the input level on the RXDX12 pin not matching on three consecutive cycles of the bus collision detection clock                                                                                                                 |  |
| SCIX3 interrupt (valid edge detected)             | AEDF  | Detection of a valid edge during bit rate measurement                                                                                                                                                                                                                  |  |

## 23.12 Usage Notes

# 23.12.1 Setting the Module Stop Function

Module stop control register B (MSTPCRB) is used to stop and start SCI operations. With the value after a reset, SCI operations are stopped. Register access is enabled by releasing the module stop state. For details, refer to section 11, Low Power Consumption.

## 23.12.2 Break Detection and Processing

When a framing error is detected, a break can be detected by reading the RXDn pin value directly. In a break, the input from the RXDn pin becomes all 0s, and so the FER flag in the SSR register is set to 1 (framing error has occurred), and the PER flag in the SSR register may also be set to 1 (parity error has occurred). When the SEMR.RXDESEL bit is 0, the SCI continues the receive operation even after a break is received. Therefore, note that even if the FER flag is set to 0 (no framing error occurred), it will be set to 1 again. When the SEMR.RXDESEL bit is 1, the SCI sets the SSR.FER flag to 1 and stops receiving operation until a start bit of the next data frame is detected. If the SSR.FER flag is set to 0 at this time, the SSR.FER flag retains 0 during the break. When the RXDn pin becomes high and the break ends, detecting the beginning of the start bit at the first falling edge of the RXDn pin allows the SCI to start the receiving operation.

# 23.12.3 Mark State and Generating Breaks

When the SCR.TE bit is 0 (serial transmission is disabled), setting the I/O port function makes selection of the level and direction (input or output) of the TXDn pin possible. If this is done, the TXDn pin can be placed in the mark state to send a break at the time of data transmission. Until the SCR.TE bit is set to 1 (serial transmission is enabled), the I/O port function is used to set the TXDn pin to output high and set the pin mode to a general I/O port pin, and thus place the communication line in the mark state (state of having the value 1). On the other hand, to output a break at the time of data transmission, set the TXDn pin to output low and make the pin mode settings for a general I/O port pin. When the SCR.TE bit is set to 0, the transmitter is initialized regardless of the current state of transmission.

# 23.12.4 Receive Error Flags and Transmit Operations (Clock Synchronous Mode and Simple SPI Mode)

Transmission cannot be started when a receive error flag (ORER) in the SSR register is set to 1, even if data is written to the TDR register. Be sure to set the receive error flags to 0 before starting transmission. Note also that the receive error flags cannot be set to 0 even if the RE bit in the SCR register is set to 0 (serial reception is disabled).

## 23.12.5 Writing Data to the TDR Register

Data can be written to the TDR register. However, if new data is written to the TDR register when transmit data is remaining in the TDR register, the previous data in the TDR register is lost because it has not been transferred to the TSR register yet. Be sure to write transmit data to the TDR register in the TXI interrupt request handling routine.



# 23.12.6 Restrictions on Clock Synchronous Transmission (Clock Synchronous Mode and Simple SPI Mode)

When the external clock source is used as a synchronization clock, the following restrictions apply.

#### (1) Start of transmission

Update TDR by the CPU or DTC and wait for at least five PCLK cycles before allowing the transmit clock to be input (refer to Figure 23.72).

#### (2) Continuous transmission

- (a) Write the next transmit data to TDR or TDRL before the falling edge of the transmit clock (bit 7) (refer to Figure 23.72).
- (b) When updating TDR after bit 7 has started to transmit, update TDR while the synchronization clock is in the low-level period, and set the high-level width of the transmit clock (bit 7) to four PCLK cycles or longer (refer to Figure 23.72).



Figure 23.72 Restrictions on Use of External Clock in Clock Synchronous Transmission

## 23.12.7 Restrictions on Using DTC

When using the DTC to read RDR, be sure to set the receive data full interrupt (RXI) as the activation source of the relevant SCI.

## 23.12.8 Notes on Starting Transfer

At the point where transfer starts when the interrupt status flag (IRn.IR bit) in the interrupt controller is 1, follow the procedure below to clear interrupt requests before permitting operations (by setting the SCR.TE or SCR.RE bit to 1). For details on the interrupt status flag, refer to section 14, Interrupt Controller (ICUb).

- Confirm that transfer has stopped (the setting of the SCR.TE or SCR.RE bits is 0).
- Set the corresponding interrupt enable bit (SCR.TIE or SCR.RIE) to 0.
- Read the corresponding interrupt enable bit (SCR.TIE or SCR.RIE bit) to check that it has become 0.
- Set the interrupt status flag (IRn.IR bit) in the interrupt controller to 0.

## 23.12.9 SCI Operations during Low Power Consumption State

#### (1) Transmission

When making settings for the module stopped state or in transitions to software standby, stop operations (by setting the TIE, TE, and TEIE bits in the SCR to 0) after switching the TXDn pin to the general I/O port pin function. Setting the TE bit to 0 resets the TSR register and the TEND bit in the SSR. Depending on the port settings, output pins may output the level before a transition to the low power consumption state is made after release from the module stopped state or software standby mode. When transitions to these states are made during transmission, the data being transmitted become indeterminate.

To transmit data in the same transmission mode after cancellation of the low power consumption state, set the TE bit to 1, read SSR, and write data to TDR sequentially to start data transmission. To transmit data with a different transmission mode, initialize the SCI first.

Figure 23.73 shows a sample flowchart for transition to software standby mode during transmission. Figure 23.74 and Figure 23.75 show the port pin states during transition to software standby mode.

Before specifying the module stop state or making a transition to software standby mode from the transmission mode using DTC transfer, stop the transmit operations (TE = 0). To start transmission after cancellation using the DTC, set the TE and TIE bits to 1. The TXI interrupt flag is set to 1 and transmission starts using the DTC.

#### (2) Reception

Before specifying the module stop state or making a transition to software standby mode, stop the receive operations (RE = 0 in the SCR register). If transition is made during data reception, the data being received will be invalid.

To receive data in the same reception mode after cancellation of the low power consumption state, set the RE bit to 1, and then start reception. To receive data in a different reception mode, initialize the SCI first.

Figure 23.76 shows a sample flowchart for transition to software standby mode during reception.





Figure 23.73 Example of Flowchart for Transition to Software Standby Mode during Transmission



Figure 23.74 Port Pin States during Transition to Software Standby Mode (Internal Clock, Asynchronous Transmission)



Figure 23.75 Port Pin States during Transition to Software Standby Mode (Internal Clock, Clock Synchronous Transmission)



Figure 23.76 Example of Flowchart for Transition to Software Standby Mode during Reception

## 23.12.10 External Clock Input in Clock Synchronous Mode and Simple SPI Mode

In clock synchronous mode and simple SPI mode, the external clock SCKn must be input as follows: High-pulse period, low-pulse period = 2 PCLK cycles or more, period = 6 PCLK cycles or more

### 23.12.11 Limitations on Simple SPI Mode

#### (1) Master Mode

- Use a resistor to pull up or pull down the clock line matching the initial settings for the transfer clock set by the SPMR.CKPH and CKPOL bits when the SPMR.SSE bit is 1.
  - This prevents the clock line from being placed in the high-impedance state when the SCR.TE bit is set to 0 or unexpected edges from being generated on the clock line when the SCR.TE bit is changed from 0 to 1. When the SPMR.SSE bit is 0 in single master mode, pulling up or pulling down the clock line is not necessary because the clock line is not placed in the high-impedance state even when the SCR.TE bit is set to 0.
- In the case of the setting for clock delay (SPMR.CKPH bit is 1), the receive data full interrupt (RXI) is generated before the final clock edge on the SCKn pin as indicated in Figure 23.77. If the TE and RE bits in the SCR become 0 at this time before the final edge of the clock signal on the SCKn pin, the SCKn pin is placed in the high-impedance state, so the width of the last clock pulse of the transfer clock is shortened. Furthermore, an RXI interrupt may lead to the input signal on the SSn# pin of a connected slave going to the high level before the final edge of the clock signal on the SCKn pin, leading to incorrect operation of the slave.
- In a multi-master configuration, take care because the SCKn pin output becomes high-impedance while the input on the SSn# pin is at the low level if a mode fault error occurs as the current character is being transferred, stopping supply of the clock signal to the connected slave. Remake the settings for the connected slave to avoid misaligned bits when transfer is restarted.



Figure 23.77 Timing of the RXI Interrupt in Simple SPI Mode (with Clock Delay)

### (2) Slave Mode

- Provide an external clock signal from the master the same as the transmit/receive data length.
- Control the input on the SSn# pin before the start and after the end of data transfer.
- When the level being input on the SSn# pin is to be changed from low to high while the current character is being transferred, set the TE and RE bits in the SCR to 0 and, after remaking the settings, restart transfer of the first byte.

#### 23.12.12 Limitation 1 on Usage of the Extended Serial Mode Control Section

When the PCR.SHARPS bit is set to 1, output on the TXDX12/RXDX12 pin is only possible when the following conditions apply.

- The timer of the SCIf module is in Break Field low width output mode and the value of the TCR.TCST bit is 1 (when the TCST bit is set to 1, the high level continues to be output for up to one cycle of the clock source for counting by the timer counter before output of the low level)
- The value of the SCI12.SCR.TE bit is 1.



## 23.12.13 Limitation 2 on Usage of the Extended Serial Mode Control Section

An SCIe interrupt request is generated even if the extended serial mode is enabled. However, the SCIe interrupt should not be used during reception of a Start Frame because SCIf uses an SCIe interrupt request.

The two ways of dealing with this are described below. When a receive error is detected, clear the error flag of the SCIe and initialize the control section of the SCIf.

- (1) Set the SCR.RIE bit of the SCIe to 0 to disable the output of interrupt requests. Check the error flags in the SSR register for SCIe on completion of the reception of a Start Frame, because an ERI interrupt is not generated if a receive error occurs. After reception of the Start Frame is completed, set the SCR.RIE bit of the SCIe to 1 by the time the first byte of the Information Frame is received.
- (2) Set the SCR.RIE bit of the SCIe to 1 to disable RXI interrupts and enable ERI interrupts for ICU. Clear the IRn.IR flag to enable the acceptance of RXI interrupts by ICU by the time the first byte of the Information Frame is received after the completion of Start Frame reception.



Figure 23.78 Example of Flowchart for Receive Error Handling (during Reception of the Start Frame)

### 23.12.14 Note on Transmit Enable Bit (TE Bit)

When setting the SCR.TE bit to 0 (serial transmission is disabled) while the pin function is "TXDn", output of the pin becomes high impedance.

Prevent the TXDn line from becoming high impedance by any of the following ways:

- (1) Connect a pull-up resistor to the TXDn line.
- (2) Change the pin function to "general-purpose I/O port, output" before setting the SCR.TE bit to 0. Set the SCR.TE bit to 1 before changing the pin function to "TXDn".

## 23.12.15 Note on Stopping Reception When the RTS Function is in Use

One clock cycle of PCLK is required for the time from setting the SCR.RE bit to 0 to stopping the RTS signal generator. When reading the RDR (or RDRL) register after setting the SCR.RE bit to 0, confirm that the RE bit has been set to 0 before reading the RDR (or RDRL) register to prevent these two processes from being performed consecutively.

# 24. I<sup>2</sup>C-bus Interface (RIIC)

This MCU has a single-channel I<sup>2</sup>C-bus interface (RIIC).

The RIIC module conforms with the NXP I<sup>2</sup>C-bus (Inter-IC bus) interface and provides a subset of its functions. In this section, "PCLK" is used to refer to PCLKB.

### 24.1 Overview

Table 24.1 lists the specifications of the RIIC, Figure 24.1 shows a block diagram of the RIIC, and Figure 24.2 shows an example of I/O pin connections to external circuits (I<sup>2</sup>C-bus configuration example). Table 24.2 lists the I/O pins of the RIIC.

Table 24.1 RIIC Specifications (1/2)

| Item                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Communications format            | <ul> <li>I<sup>2</sup>C-bus format or SMBus format</li> <li>Master mode or slave mode selectable</li> <li>Automatic securing of the various setup times, hold times, and bus-free times for the transfer rate</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Transfer rate                    | Fast-mode is supported (up to 400 kbps)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| SCL clock                        | For master operation, the duty cycle of the SCL clock is selectable in the range from 4 to 96%.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Issuing and detecting conditions | Start, restart, and stop conditions are automatically generated. Start conditions (including restart conditions) and stop conditions are detectable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Slave address                    | <ul> <li>Up to three different slave addresses can be set.</li> <li>7-bit and 10-bit address formats are supported (along with the use of both at once).</li> <li>General call addresses, device ID addresses, and SMBus host addresses are detectable.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Acknowledgment                   | <ul> <li>For transmission, the acknowledge bit is automatically loaded. Transfer of the next data for transmission can be automatically suspended on detection of a not-acknowledge bit.</li> <li>For reception, the acknowledge bit is automatically transmitted. If a wait between the eighth and ninth clock cycles has been selected, software control of the value in the acknowledge field in response to the received value is possible.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Wait function                    | In reception, the following periods of waiting can be obtained by holding the SCL clock at the low level:     Waiting between the eighth and ninth clock cycles     Waiting between the ninth clock cycle and the first clock cycle of the next transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| SDA output delay function        | Timing of the output of transmitted data, including the acknowledge bit, can be delayed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Arbitration                      | <ul> <li>For multi-master operation Operation to synchronize the SCL clock in cases of conflict with the SCL signal from another master is possible. When issuing the start condition would create conflict on the bus, loss of arbitration is detected by testing for non-matching between the internal signal for the SDA line and the level on the SDA line. In master operation, loss of arbitration is detected by testing for non-matching between the signal on the SDA line and the internal signal for the SDA line.</li> <li>Loss of arbitration due to detection of the start condition while the bus is busy is detectable (to prevent the issuing of double start conditions).</li> <li>Loss of arbitration in transfer of a not-acknowledge bit due to the internal signal for the SDA line and the level on the SDA line not matching is detectable.</li> <li>Loss of arbitration due to non-matching of internal and line levels for data is detectable in slave transmission.</li> </ul> |
| Timeout function                 | The internal timeout function is capable of detecting long-interval stop of the SCL clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Noise cancellation               | The interface incorporates digital noise filters for both the SCL and SDA signals, and the width for noise cancellation by the filters is adjustable by software.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Interrupt sources                | Four sources:  • Error in transfer or occurrence of events Detection of arbitration, NACK, timeout, a start condition including a restart condition, or a stop condition • Receive data full (including matching with a slave address) • Transmit data empty (including matching with a slave address) • Transmit end                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Table 24.1 RIIC Specifications (2/2)

| Item                           | Description                                                                                     |
|--------------------------------|-------------------------------------------------------------------------------------------------|
| Low power consumption function | Module stop state can be set.                                                                   |
| RIIC operating modes           | Four     Master transmit mode, master receive mode, slave transmit mode, and slave receive mode |



Figure 24.1 RIIC Block Diagram



Figure 24.2 I/O Pin Connection to the External Circuit (I<sup>2</sup>C-bus Configuration Example)

The input level of the signals for RIIC is CMOS when I<sup>2</sup>C-bus is selected (ICMR3.SMBS bit is 0), or TTL when SMBus is selected (ICMR3.SMBS bit is 1).

Table 24.2 RIIC Pin Configuration

| Channel | Pin Name | 1/0 | Function                   |
|---------|----------|-----|----------------------------|
| RIIC0   | SCL0     | I/O | RIIC0 serial clock I/O pin |
|         | SDA0     | I/O | RIIC0 serial data I/O pin  |

## 24.2 Register Descriptions

## 24.2.1 I<sup>2</sup>C-bus Control Register 1 (ICCR1)

Address(es): RIIC0.ICCR1 0008 8300h



| Bit | Symbol | Bit Name                                         | Description                                                                                                                                                                                                                           | R/W |
|-----|--------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | SDAI   | SDA Line Monitor                                 | 0: SDA0 line is low.<br>1: SDA0 line is high.                                                                                                                                                                                         | R   |
| b1  | SCLI   | SCL Line Monitor                                 | 0: SCL0 line is low. 1: SCL0 line is high.                                                                                                                                                                                            | R   |
| b2  | SDAO   | SDA Output Control/Monitor                       | <ul> <li>Read:</li> <li>0: The RIIC has driven the SDA0 pin low.</li> <li>1: The RIIC has released the SDA0 pin.</li> <li>Write:</li> <li>0: The RIIC drives the SDA0 pin low.</li> <li>1: The RIIC releases the SDA0 pin.</li> </ul> | R/W |
| b3  | SCLO   | SCL Output Control/Monitor                       | Read:  The RIIC has driven the SCL0 pin low.  The RIIC has released the SCL0 pin.  Write:  The RIIC drives the SCL0 pin low.  The RIIC drives the SCL0 pin.  High level output is achieved through an external pull-up resistor.)     | R/W |
| b4  | SOWP   | SCLO/SDAO Write Protect                          | 0: SCLO and SDAO bits can be written. 1: SCLO and SDAO bits are protected. (This bit is read as 1.)                                                                                                                                   | R/W |
| b5  | CLO    | Extra SCL Clock Cycle Output                     | O: Does not output an extra SCL clock cycle (default).  1: Outputs an extra SCL clock cycle.  (The CLO bit is cleared automatically after one clock cycle is output.)                                                                 | R/W |
| b6  | IICRST | I <sup>2</sup> C-bus Interface Internal<br>Reset | 0: Releases the RIIC reset or internal reset.  1: Initiates the RIIC reset or internal reset.  (Clears the bit counter and the SCL0/SDA0 output latch)                                                                                | R/W |
| b7  | ICE    | I <sup>2</sup> C-bus Interface Enable            | 0: Disable (SCL0 and SDA0 pins in inactive state) 1: Enable (SCL0 and SDA0 pins in active state) (Combined with the IICRST bit to select either RIIC or internal reset.)                                                              | R/W |

### SDAO Bit (SDA Output Control/Monitor) and SCLO Bit (SCL Output Control/Monitor)

These bits are used to directly control the SDA0 and SCL0 signals output from the RIIC.

When writing to these bits, also write 0 to the SOWP bit.

The result of setting these bits is input to the RIIC via the input buffer. When slave mode is selected, a start condition may be detected and the bus may be released depending on the bit settings.

Do not rewrite these bits during a start condition, stop condition, restart condition, or during transmission or reception.

Operation after rewriting under the above conditions is not guaranteed.

When reading these bits, the state of signals output from the RIIC can be read.



#### **CLO Bit (Extra SCL Clock Cycle Output)**

This bit is used to output an extra SCL clock cycle for debugging or error processing.

Normally, set the bit to 0. Setting the bit to 1 in a normal communication state causes a communication error.

For details on this function, refer to section 24.11.2, Extra SCL Clock Cycle Output Function.

#### **IICRST Bit (I<sup>2</sup>C-bus Interface Internal Reset)**

This bit is used to reset the internal states of the RIIC.

Setting this bit to 1 initiates an RIIC reset or internal reset.

Whether an RIIC reset or internal reset is initiated is determined according to the combination with the ICE bit. Table 24.3 lists the resets of the RIIC.

The RIIC reset resets all registers and internal states of the RIIC, and the internal reset resets the bit counter (ICMR1.BC[2:0] bits), the I<sup>2</sup>C-bus shift register (ICDRS), and the I<sup>2</sup>C-bus status registers (ICSR1 and ICSR2) as well as the internal states of the RIIC. For the reset conditions for each register, refer to section 24.14, Resets and Register and Function States When Issuing Each Condition.

An internal reset initiated with the IICRST bit set to 1 during operation (with the ICE bit set to 1) resets the internal states of the RIIC without initializing the port settings and the control and setting registers of the RIIC when the bus or RIIC hangs up due to a communication error.

If the RIIC hangs up in a low level output state, resetting the internal states cancels the low level output state and releases the bus with the SCL0 pin and SDA0 pin at a high impedance.

Note:

If an internal reset is initiated using the IICRST bit for a bus hang-up occurred during communication with the master device in slave mode, the states may become different between the slave device and the master device (due to the difference in the bit counter information). For this reason, do not initiate an internal reset in slave mode, but initiate restoration processing from the master device. If an internal reset is necessary because the RIIC hangs up with the SCL0 line in a low level output state in slave mode, initiate an internal reset and then issue a restart condition from the master device or resume communication from the start condition issuance after issuing a stop condition. If communication is restarted by initiating a reset solely in the slave device without issuing a start condition or restart condition from the master device, synchronization will be lost because the master and slave devices operate asynchronously.

Table 24.3 RIIC Resets

| IICRST | ICE | State          | Specifications                                                                                         |
|--------|-----|----------------|--------------------------------------------------------------------------------------------------------|
| 1      | 0   | RIIC reset     | Resets all registers and internal states of the RIIC.                                                  |
|        | 1   | Internal reset | Resets the ICMR1.BC[2:0] bits, registers ICSR1, ICSR2, and ICDRS, and the internal states of the RIIC. |

#### ICE Bit (I<sup>2</sup>C-bus Interface Enable)

This bit selects the active or inactive state of the SCL0 and SDA0 pins. It can also be combined with the IICRST bit to initiate two types of resets. See Table 24.3, RIIC Resets, for the types of resets.

Set the ICE bit to 1 when using the RIIC. The SCL0 and SDA0 pins are placed in the active state when the ICE bit is set to 1.

Set the ICE bit to 0 when the RIIC is not to be used. The SCL0 and SDA0 pins are placed in the inactive state when the ICE bit is set to 0. Do not assign the SCL0 or SDA0 pin to the RIIC when setting up the multi-function pin controller (MPC). Note that the slave address comparison operation is carried out if the pins are assigned to the RIIC.



## 24.2.2 I<sup>2</sup>C-bus Control Register 2 (ICCR2)

Address(es): RIIC0.ICCR2 0008 8301h



| Bit | Symbol | Bit Name                              | Description                                                                                                         | R/W   |
|-----|--------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------|-------|
| b0  | _      | Reserved                              | This bit is read as 0. The write value should be 0.                                                                 | R/W   |
| b1  | ST     | Start Condition Issuance<br>Request   | O: Does not request to issue a start condition.  1: Requests to issue a start condition.                            | R/W   |
| b2  | RS     | Restart Condition Issuance<br>Request | Does not request to issue a restart condition.     Requests to issue a restart condition.                           | R/W   |
| b3  | SP     | Stop Condition Issuance<br>Request    | Does not request to issue a stop condition.     Requests to issue a stop condition.                                 | R/W   |
| b4  | _      | Reserved                              | This bit is read as 0. The write value should be 0.                                                                 | R/W   |
| b5  | TRS    | Transmit/Receive Mode                 | 0: Receive mode<br>1: Transmit mode                                                                                 | R/W*1 |
| b6  | MST    | Master/Slave Mode                     | 0: Slave mode<br>1: Master mode                                                                                     | R/W*1 |
| b7  | BBSY   | Bus Busy Detection Flag               | 0: The I <sup>2</sup> C-bus is released (bus free state). 1: The I <sup>2</sup> C-bus is occupied (bus busy state). | R     |

Note 1. When the ICMR1.MTWP bit is set to 1, bits MST and TRS can be written to.

#### ST Bit (Start Condition Issuance Request)

This bit is used to request transition to master mode and issuance of a start condition.

When this bit is set to 1 to request to issue a start condition, a start condition is issued when the BBSY flag is set to 0 (bus free state).

For details on the start condition issuance, refer to section 24.10, Start Condition/Restart Condition/Stop Condition Issuing Function.

[Setting condition]

• When 1 is written to the ST bit

[Clearing conditions]

- When 0 is written to the ST bit
- When a start condition has been issued (a start condition is detected)
- When the ICSR2.AL (arbitration-lost) flag is set to 1
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

Note: Set the ST bit to 1 (start condition issuance request) when the BBSY flag is set to 0 (bus free state).

Note that arbitration may be lost due to a start condition issuance error if the ST bit is set to 1 (start condition issuance request) when the BBSY flag is set to 1 (bus busy state).

#### **RS Bit (Restart Condition Issuance Request)**

This bit is used to request that a restart condition be issued in master mode.

When this bit is set to 1 to request to issue a restart condition, a restart condition is issued when the BBSY flag is set to 1 (bus busy state) and the MST bit is set to 1 (master mode).

For details on the restart condition issuance, refer to section 24.10, Start Condition/Restart Condition/Stop Condition Issuing Function.

[Setting condition]

• When 1 is written to the RS bit with the ICCR2.BBSY flag set to 1

[Clearing conditions]

- When 0 is written to the RS bit
- When a restart condition has been issued (a start condition is detected)
- When the ICSR2.AL (arbitration-lost) flag is set to 1
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

Note: Do not set the RS bit to 1 while issuing a stop condition.

Note: If 1 (requests to issue a restart condition) is written to the RS bit in slave mode, the restart condition is not issued but the RS bit remains set to 1. If the operating mode changes to master mode with the bit not being cleared, note that the restart condition may be issued.

#### **SP Bit (Stop Condition Issuance Request)**

This bit is used to request that a stop condition be issued in master mode.

When this bit is set to 1 to request to issue a stop condition, a stop condition is issued when the BBSY flag is set to 1 (bus busy state) and the MST bit is set to 1 (master mode).

For details on the stop condition issuance, refer to section 24.10, Start Condition/Restart Condition/Stop Condition Issuing Function.

[Setting condition]

• When 1 is written to the SP bit with both the BBSY flag and the ICCR2.MST bit set to 1

[Clearing conditions]

- When 0 is written to the SP bit
- When a stop condition has been issued (a stop condition is detected)
- When the ICSR2.AL (arbitration-lost) flag is set to 1
- When a start condition and a restart condition are detected
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

Note: Writing to the SP bit is not possible while the setting of the BBSY flag is 0 (bus free state).

Note: Do not set the SP bit to 1 while a restart condition is being issued.



#### TRS Bit (Transmit/Receive Mode)

This bit indicates transmit or receive mode.

The RIIC is in receive mode when the TRS bit is set to 0 and is in transmit mode when the bit is set to 1. Combination of this bit and the MST bit indicates the operating mode of the RIIC.

The value of TRS bit is automatically changed to 1 for transmit mode or 0 for receive mode by issuing or detection of a start condition and setting of the R/W# bit. Although writing to the TRS bit is possible when the ICMR1.MTWP bit is set to 1, writing to this bit is not necessary during normal usage.

#### [Setting conditions]

- When a start condition is issued normally according to the start condition issuance request (when a start condition is detected with the ST bit set to 1)
- When a restart condition is issued normally according to the restart condition issuance request (when a restart condition is detected with the RS bit set to 1)
- When the R/W# bit added to the slave address is set to 0 in master mode
- When the address received in slave mode matches the address enabled in the ICSER register, with the R/W# bit set to 1
- When 1 is written to the TRS bit with the ICMR1.MTWP bit set to 1

#### [Clearing conditions]

- When a stop condition is detected
- The ICSR2.AL (arbitration-lost) flag being set to 1
- In master mode, reception of a slave address to which an R/W# bit with the value 1 is appended
- In slave mode, a match between the received address and the address enabled in the ICSER register when the value of the received R/W# bit is 0 (including cases where the received address is the general call address)
- In slave mode, a restart condition is detected (a start condition is detected with ICCR2.BBSY flag is 1 and ICCR2.MST bit is 0)
- When 0 is written to the TRS bit with the ICMR1.MTWP bit set to 1
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

#### MST Bit (Master/Slave Mode)

This bit indicates master or slave mode.

The RIIC is in slave mode when the MST bit is set to 0 and is in master mode when the bit is set to 1. Combination of this bit and the TRS bit indicates the operating mode of the RIIC.

The value of the MST bit is automatically changed to 1 for master mode or 0 for slave mode by issuing of a start condition and issuing or detection of a stop condition, etc. Although writing to the MST bit is possible when the ICMR1.MTWP bit is set to 1, writing to this bit is not necessary during normal usage.

#### [Setting conditions]

- When a start condition is issued normally according to the start condition issuance request (when a start condition is detected with the ST bit set to 1)
- When 1 is written to the MST bit with the ICMR1.MTWP bit set to 1

#### [Clearing conditions]

- When a stop condition is detected
- When the ICSR2.AL (arbitration-lost) flag is set to 1
- When 0 is written to the MST bit with the ICMR1.MTWP bit set to 1
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset



#### **BBSY Flag (Bus Busy Detection Flag)**

The BBSY flag indicates whether the I<sup>2</sup>C-bus is occupied (bus busy state) or released (bus free state).

This bit is set to 1 when the SDA0 line changes from high to low under the condition of SCL0 line = high, assuming that a start condition has been issued.

When the SDA0 line changes from low to high under the condition of SCL0 line = high, this bit is set to 0 after the bus free time (specified in the ICBRL register) start condition is not detected, assuming that a stop condition has been issued. [Setting condition]

• When a start condition is detected

[Clearing conditions]

- When the bus free time (specified in the ICBRL register) start condition is not detected after detecting a stop condition
- When 1 is written to the ICCR1.IICRST bit with the ICCR1.ICE bit set to 0 (RIIC reset)

## 24.2.3 I<sup>2</sup>C-bus Mode Register 1 (ICMR1)

Address(es): RIIC0.ICMR1 0008 8302h



| Bit      | Symbol   | Bit Name                        | Description                                                                                                                                                                                                                                | R/W   |
|----------|----------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| b2 to b0 | BC[2:0]  | Bit Counter                     | b2 b0<br>0 0 0:9 bits<br>0 0 1:2 bits<br>0 1 0:3 bits<br>0 1 1:4 bits<br>1 0 0:5 bits<br>1 0 1:6 bits<br>1 1 0:7 bits<br>1 1 1:8 bits                                                                                                      | R/W*1 |
| b3       | BCWP     | BC Write Protect                | 0: Enables a value to be written in the BC[2:0] bits. (This bit is read as 1.)                                                                                                                                                             | R/W*1 |
| b6 to b4 | CKS[2:0] | Internal Reference Clock Select | Select the internal reference clock (IICφ) source for the RIIC.  b6 b4 0 0 0: PCLK/1 clock 0 0 1: PCLK/2 clock 0 1 0: PCLK/4 clock 0 1 1: PCLK/8 clock 1 0 0: PCLK/16 clock 1 0 1: PCLK/32 clock 1 1 1: PCLK/32 clock 1 1 1: PCLK/64 clock | R/W   |
| b7       | MTWP     | MST/TRS Write Protect           | Disables writing to the ICCR2.MST and TRS bits.     Enables writing to the ICCR2.MST and TRS bits.                                                                                                                                         | R/W   |

Note 1. Rewrite the BC[2:0] bits and set the BCWP bit to 0 at the same time.

### BC[2:0] Bits (Bit Counter)

These bits function as a counter that indicates the number of bits remaining to be transferred at the detection of a rising edge on the SCL0 line. Although these bits are writable and readable, it is not necessary to access these bits under normal conditions.

To write to these bits, specify the number of bits to be transferred plus one (data is transferred with an additional acknowledge bit) between transferred bytes when the SCL0 line is at a low level.

The values of the BC[2:0] bits return to 000b at the end of a data transfer including the acknowledge bit or when a start condition including a restart condition is detected.

## 24.2.4 I<sup>2</sup>C-bus Mode Register 2 (ICMR2)

Address(es): RIIC0.ICMR2 0008 8303h



| Bit      | Symbol    | Bit Name                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                             | R/W |
|----------|-----------|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0       | TMOS      | Timeout Detection Time Select            | 0: Long mode is selected. 1: Short mode is selected.                                                                                                                                                                                                                                                                                                                                                                                    | R/W |
| b1       | TMOL      | Timeout L Count Control                  | 0: Count-up is disabled while the SCL0 line is at a low level.  1: Count-up is enabled while the SCL0 line is at a low level.                                                                                                                                                                                                                                                                                                           | R/W |
| b2       | TMOH      | Timeout H Count Control                  | 0: Count-up is disabled while the SCL0 line is at a high level.  1: Count-up is enabled while the SCL0 line is at a high level.                                                                                                                                                                                                                                                                                                         | R/W |
| b3       | TMWE      | Timeout Internal Counter Write<br>Enable | O: Writing to internal counter of timeout detection function is disabled.  1: Writing to internal counter of timeout detection function is enabled.                                                                                                                                                                                                                                                                                     | R/W |
| b6 to b4 | SDDL[2:0] | SDA Output Delay Counter                 | • When ICMR2.DLCS bit is 0 (IICφ)  b6 b4  0 0 0: No output delay  0 0 1: 1 IICφ cycle  0 1 0: 2 IICφ cycles  0 1 1: 3 IICφ cycles  1 0 0: 4 IICφ cycles  1 0 1: 5 IICφ cycles  1 1 0: 6 IICφ cycles  1 1 1: 7 IICφ cycles  • When ICMR2.DLCS bit is 1 (IICφ/2)  b6 b4  0 0 0: No output delay  0 0 1: 1 or 2 IICφ cycles  0 1 0: 3 or 4 IICφ cycles  1 0 0: 7 or 8 IICφ cycles  1 0 1: 9 or 10 IICφ cycles  1 1 0: 11 or 12 IICφ cycles | R/W |
| b7       | DLCS      | SDA Output Delay Clock Source<br>Select  | <ul> <li>0: The internal reference clock (IICφ) is selected as the clock source of the SDA output delay counter.</li> <li>1: The internal reference clock divided by 2 (IICφ/2) is selected as the clock source of the SDA output delay counter.*1</li> </ul>                                                                                                                                                                           | R/W |

Note 1. The DLCS bit setting of 1 (IIC $\phi$ /2) only becomes valid when SCL pin is low. When SCL pin is high, the DLCS bit setting of 1 becomes invalid and the clock source becomes the internal reference clock (IIC $\phi$ ).

#### **TMOS Bit (Timeout Detection Time Select)**

This bit is used to select long mode or short mode for the timeout detection time when the timeout function is enabled (ICFER.TMOE bit is 1). When this bit is set to 0, long mode is selected. When this bit is set to 1, short mode is selected. In long mode, the timeout detection internal counter functions as a 16-bit counter. In short mode, the counter functions as a 14-bit counter. While the SCL0 line is in the state that enables this counter as specified by bits TMOH and TMOL, the counter counts up in synchronization with the internal reference clock (IIC $\phi$ ) as a count source.

For details on the timeout function, refer to section 24.11.1, Timeout Function.

#### **TMOL Bit (Timeout L Count Control)**

This bit is used to enable or disable the internal counter of the timeout function to count up while the SCL0 line is held low when the timeout function is enabled (ICFER.TMOE bit is 1).



#### **TMOH Bit (Timeout H Count Control)**

This bit is used to enable or disable the internal counter of the timeout function to count up while the SCL0 line is held high when the timeout function is enabled (ICFER.TMOE bit is 1).

#### **TMWE Bit (Timeout Internal Counter Write Enable)**

This bit is used to select whether or not to allocate the timeout internal counter (TMOCNTL/TMOCNTU) to the address of the slave address register (SARL0/SARU0).

When this bit is set to 1, the addresses of the timeout internal counters (TMOCNTL and TMOCNTU) are allocated to the addresses of SARL0 and SARU0.

#### SDDL[2:0] Bits (SDA Output Delay Counter)

The SDA output can be delayed by the SDDL[2:0] setting. This counter works with the clock source selected by the DLCS bit. The setting of this function can be used for all types of SDA output, including the transmission of the acknowledge bit.

Set the SDA output delay time to meet the I<sup>2</sup>C-bus specification (within the data enable time/acknowledge enable time\*<sup>1</sup>) or the SMBus specification (within the data hold time: 300 ns or more, and SCL-clock low-level period - the data setup time: 250 ns). Note that, if a value outside the specification is set, communication with communication devices may malfunction or it may seemingly become a start condition or stop condition depending on the bus state. For details on this function, refer to section 24.5, SDA Output Delay Function.

Note 1. Data enable time/acknowledge enable time 3,450 ns (up to 100 kbps: Standard-mode (Sm)) 900 ns (up to 400 kbps: Fast-mode (Fm))

## 24.2.5 I<sup>2</sup>C-bus Mode Register 3 (ICMR3)

Address(es): RIIC0.ICMR3 0008 8304h



| Bit    | Symbol  | Bit Name                          | Description                                                                                                                                                                                                                                                                                                                                                                | R/W   |
|--------|---------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| b1, b0 | NF[1:0] | Noise Filter Stage Select         | b1 b0 0 0: Noise of up to one IIC $\phi$ cycle is filtered out (single-stage filter). 0 1: Noise of up to two IIC $\phi$ cycles is filtered out (2-stage filter). 1 0: Noise of up to three IIC $\phi$ cycles is filtered out (3-stage filter). 1 1: Noise of up to four IIC $\phi$ cycles is filtered out (4-stage filter).                                               | R/W   |
| b2     | ACKBR   | Receive Acknowledge               | 0: 0 is received as the acknowledge bit (ACK reception).  1: 1 is received as the acknowledge bit (NACK reception).                                                                                                                                                                                                                                                        | R     |
| b3     | ACKBT   | Transmit Acknowledge              | 0: 0 is sent as the acknowledge bit (ACK transmission).  1: 1 is sent as the acknowledge bit (NACK transmission).                                                                                                                                                                                                                                                          | R/W*1 |
| b4     | ACKWP   | ACKBT Write Protect               | Modification of the ACKBT bit is disabled.     Modification of the ACKBT bit is enabled.                                                                                                                                                                                                                                                                                   | R/W*1 |
| b5     | RDRFS   | RDRF Flag Set Timing<br>Select    | O: The RDRF flag is set at the rising edge of the ninth SCL clock cycle.  (The SCL0 line is not held low at the falling edge of the eighth clock cycle.)  1: The RDRF flag is set at the rising edge of the eighth SCL clock cycle.  (The SCL0 line is held low at the falling edge of the eighth clock cycle.)  Low-hold is released by writing a value to the ACKBT bit. | R/W*2 |
| b6     | WAIT    | WAIT                              | O: No WAIT  (The period between ninth clock cycle and first clock cycle is not held low.)  1: WAIT  (The period between ninth clock cycle and first clock cycle is held low.)  Low-hold is released by reading the ICDRR register.                                                                                                                                         | R/W*2 |
| b7     | SMBS    | SMBus/I <sup>2</sup> C-bus Select | 0: The I <sup>2</sup> C-bus is selected. 1: The SMBus is selected.                                                                                                                                                                                                                                                                                                         | R/W   |

Note 1. Write to the ACKBT bit only while the ACKWP bit is already 1. If it is attempted to write 1 to both the ACKWP and ACKBT bits at the same time, the ACKBT bit will not be set to 1.

#### NF[1:0] Bits (Noise Filter Stage Select)

These bits are used to select the number of stages in the digital noise filter.

For details on the digital noise filter function, refer to section 24.6, Digital Noise Filter Circuit.

Note: Set the noise range to be filtered out by the noise filter within a range less than the SCL0 line high-level period or low-level period. If the noise filter width is set to a value of [the shorter one of either SCL high width or SCL low width] – {1.5 × t<sub>IICcyc</sub> (cycle time of internal reference clock (IICφ)) + 120 ns (pulse width suppressed by the analog noise filter, a reference value)} or a greater value, the SCL clock is regarded as noise by the noise filter function of the RIIC, which may prevent the RIIC from operating normally.

Note 2. The WAIT and RDRFS bits are valid only in receive mode (invalid in transmit mode).

#### **ACKBR Bit (Receive Acknowledge)**

This bit is used to store the acknowledge bit information received from the receive device in transmit mode. [Setting condition]

- When 1 is received as the acknowledge bit with the ICCR2.TRS bit set to 1 [Clearing conditions]
  - When 0 is received as the acknowledge bit with the ICCR2.TRS bit set to 1
- When 1 is written to the ICCR1.IICRST bit while the ICCR1.ICE bit is 0 (RIIC reset)

#### **ACKBT Bit (Transmit Acknowledge)**

This bit is used to set the bit to be sent at the acknowledge timing in receive mode. [Setting condition]

• When 1 is written to this bit with the ACKWP bit set to 1

[Clearing conditions]

- When 0 is written to this bit with the ACKWP bit set to 1
- When stop condition issuance is detected (when a stop condition is detected with the ICCR2.SP bit set to 1)
- When 1 is written to the ICCR1.IICRST bit while the ICCR1.ICE bit is 0 (RIIC reset)

#### **ACKWP Bit (ACKBT Write Protect)**

This bit is used to control the modification of the ACKBT bit.

### RDRFS Bit (RDRF Flag Set Timing Select)

This bit is used to select the RDRF flag set timing in receive mode and also to select whether to hold the SCL0 line low at the falling edge of the eighth SCL clock cycle.

When the RDRFS bit is 0, the SCL0 line is not held low at the falling edge of the eighth SCL clock cycle, and the RDRF flag is set to 1 at the rising edge of the ninth SCL clock cycle.

When the RDRFS bit is 1, the RDRF flag is set to 1 at the rising edge of the eighth SCL clock cycle and the SCL0 line is held low at the falling edge of the eighth SCL clock cycle. The low-hold of the SCL0 line is released by writing a value to the ACKBT bit.

After data is received with this setting, the SCL0 line is automatically held low before the acknowledge bit is sent. This enables processing to send ACK (ACKBT bit is 0) or NACK (ACKBT bit is 1) according to receive data.

### WAIT Bit (WAIT)

This bit is used to control whether to hold the period between the ninth SCL clock cycle and the first SCL clock cycle low until the I<sup>2</sup>C-bus receive data register (ICDRR) is completely read each time single-byte data is received in receive mode.

When the WAIT bit is 0, the receive operation is continued without holding the period between the ninth and the first SCL clock cycle low. When both the RDRFS and WAIT bits are 0, continuous receive operation is enabled with the double buffer.

When the WAIT bit is 1, the SCL0 line is held low from the falling edge of the ninth clock cycle until the ICDRR register value is read each time single-byte data is received. This enables receive operation in byte units.

Note: When the value of the WAIT bit is to be read, be sure to read the ICDRR register beforehand.

### SMBS Bit (SMBus/I<sup>2</sup>C-bus Select)

Setting this bit to 1 selects the SMBus and enables the ICSER.HOAE bit.



## 24.2.6 I<sup>2</sup>C-bus Function Enable Register (ICFER)

Address(es): RIIC0.ICFER 0008 8305h



| Bit | Symbol | Bit Name                                                  | Description                                                                                                                                                                                                                                                                                                                                                                  | R/W |
|-----|--------|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | TMOE   | Timeout Function Enable                                   | The timeout function is disabled.     The timeout function is enabled.                                                                                                                                                                                                                                                                                                       | R/W |
| b1  | MALE   | Master Arbitration-Lost<br>Detection Enable               | O: Master arbitration-lost detection is disabled. (Disables the arbitration-lost detection function and does not clear the ICCR2.MST and TRS bits automatically when arbitration is lost.)  1: Master arbitration-lost detection is enabled. (Enables the arbitration-lost detection function and clears the ICCR2.MST and TRS bits automatically when arbitration is lost.) | R/W |
| b2  | NALE   | NACK Transmission<br>Arbitration-Lost Detection<br>Enable | NACK transmission arbitration-lost detection is disabled.     NACK transmission arbitration-lost detection is enabled.                                                                                                                                                                                                                                                       | R/W |
| b3  | SALE   | Slave Arbitration-Lost<br>Detection Enable                | Slave arbitration-lost detection is disabled.     Slave arbitration-lost detection is enabled.                                                                                                                                                                                                                                                                               | R/W |
| b4  | NACKE  | NACK Reception Transfer<br>Suspension Enable              | O: Transfer operation is not suspended during NACK reception (transfer suspension disabled).  1: Transfer operation is suspended during NACK reception (transfer suspension enabled).                                                                                                                                                                                        | R/W |
| b5  | NFE    | Digital Noise Filter Circuit<br>Enable                    | O: No digital noise filter circuit is used.  1: A digital noise filter circuit is used.                                                                                                                                                                                                                                                                                      | R/W |
| b6  | SCLE   | SCL Synchronous Circuit Enable                            | 0: No SCL synchronous circuit is used. 1: An SCL synchronous circuit is used.                                                                                                                                                                                                                                                                                                | R/W |
| b7  | _      | Reserved                                                  | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                                          | R/W |

#### **TMOE Bit (Timeout Function Enable)**

This bit is used to enable or disable the timeout function.

For details on the timeout function, refer to section 24.11.1, Timeout Function.

#### MALE Bit (Master Arbitration-Lost Detection Enable)

This bit is used to specify whether to use the arbitration-lost detection function in master mode. Normally, set this bit to 1.

### NALE Bit (NACK Transmission Arbitration-Lost Detection Enable)

This bit is used to specify whether to cause arbitration to be lost when ACK is detected during transmission of NACK in receive mode (such as when slaves with the same address exist on the bus or when two or more masters select the same slave device simultaneously with different number of receive bytes).

### **SALE Bit (Slave Arbitration-Lost Detection Enable)**

This bit is used to specify whether to cause arbitration to be lost when a value different from the value being transmitted is detected on the bus in slave transmit mode (such as when slaves with the same address exist on the bus or when a mismatch with the transmit data occurs due to noise).



#### **NACKE Bit (NACK Reception Transfer Suspension Enable)**

This bit is used to specify whether to continue or discontinue the transfer operation when NACK is received from the slave device in transmit mode. Normally, set this bit to 1.

When NACK is received with the NACKE bit set to 1, the next transfer operation is suspended.

When the NACKE bit is 0, the next transfer operation is continued regardless of the received acknowledge content. For details on the NACK reception transfer suspension function, refer to section 24.8.2, NACK Reception Transfer Suspension Function.

### **SCLE Bit (SCL Synchronous Circuit Enable)**

This bit is used to specify whether to synchronize the SCL clock with the SCL input clock. Normally, set this bit to 1. When the SCLE bit is set to 0 (no SCL synchronous circuit used), the RIIC does not synchronize the SCL clock with the SCL input clock. In this setting, the RIIC outputs the SCL clock with the transfer rate set in registers ICBRH and ICBRL regardless of the SCL0 line state. For this reason, if the bus load of the I<sup>2</sup>C-bus line is much larger than the specification value or if the SCL clock output overlaps in multiple masters, the short-cycle SCL clock that does not meet the specification may be output. When no SCL synchronous circuit is used, it also affects the issuance of a start condition, restart condition, and stop condition, and the continuous output of extra SCL clock cycles.

This bit must not be set to 0 except for checking the output of the set transfer rate.



## 24.2.7 I<sup>2</sup>C-bus Status Enable Register (ICSER)

Address(es): RIIC0.ICSER 0008 8306h



| Bit | Symbol | Bit Name                              | Description                                                                                                        | R/W |
|-----|--------|---------------------------------------|--------------------------------------------------------------------------------------------------------------------|-----|
| b0  | SAR0E  | Slave Address Register 0 Enable       | Slave address in registers SARL0 and SARU0 is disabled.     Slave address in registers SARL0 and SARU0 is enabled. | R/W |
| b1  | SAR1E  | Slave Address Register 1 Enable       | Slave address in registers SARL1 and SARU1 is disabled.     Slave address in registers SARL1 and SARU1 is enabled. | R/W |
| b2  | SAR2E  | Slave Address Register 2 Enable       | Slave address in registers SARL2 and SARU2 is disabled.     Slave address in registers SARL2 and SARU2 is enabled. | R/W |
| b3  | GCAE   | General Call Address Enable           | General call address detection is disabled.     General call address detection is enabled.                         | R/W |
| b4  | _      | Reserved                              | This bit is read as 0. The write value should be 0.                                                                | R/W |
| b5  | DIDE   | Device-ID Address Detection<br>Enable | Device-ID address detection is disabled.     Device-ID address detection is enabled.                               | R/W |
| b6  | _      | Reserved                              | This bit is read as 0. The write value should be 0.                                                                | R/W |
| b7  | HOAE   | Host Address Enable                   | 0: Host address detection is disabled. 1: Host address detection is enabled.                                       | R/W |

#### SARyE Bit (Slave Address Register y Enable) (y = 0 to 2)

This bit is used to enable or disable the slave address set in registers SARLy and SARUy.

When this bit is set to 1, the slave address set in registers SARLy and SARUy is enabled and is compared with the received slave address.

When this bit is set to 0, the slave address set in registers SARLy and SARUy is disabled and is ignored even if it matches the received slave address.

#### **GCAE Bit (General Call Address Enable)**

This bit is used to specify whether to ignore the general call address ( $0000\ 000b + 0$  (write): All 0) when it is received. When this bit is set to 1, if the received slave address matches the general call address, the RIIC recognizes the received slave address as the general call address independently of the slave addresses set in registers SARLy and SARUy (y = 0 to 2) and performs data receive operation.

When this bit is set to 0, the received slave address is ignored even if it matches the general call address.

#### **DIDE Bit (Device-ID Address Detection Enable)**

This bit is used to specify whether to recognize and execute the device-ID address when a device ID (1111 100b) is received in the first byte after a start condition or restart condition is detected.

When this bit is set to 1, if the received first byte matches the device ID, the RIIC recognizes that the device-ID address has been received. When the following R/W# bit is 0 (write), the RIIC recognizes the second and the following bytes as slave addresses and continues the receive operation.

When this bit is set to 0, the RIIC ignores the received first byte even if it matches the device ID address and recognizes the first byte as a normal slave address.

For details on the device-ID address detection, refer to section 24.7.3, Device-ID Address Detection.



### **HOAE Bit (Host Address Enable)**

This bit is used to specify whether to ignore received host address (0001 000b) when the ICMR3.SMBS bit is 1.

When this bit is set to 1 while the ICMR3.SMBS bit is 1, if the received slave address matches the host address, the RIIC recognizes the received slave address as the host address independently of the slave addresses set in registers SARLy and SARUy (y = 0 to 2) and performs the receive operation.

When the ICMR3.SMBS bit or the HOAE bit is set to 0, the received slave address is ignored even if it matches the host address.



## 24.2.8 I<sup>2</sup>C-bus Interrupt Enable Register (ICIER)

Address(es): RIIC0.ICIER 0008 8307h



| Bit | Symbol | Bit Name                                              | Description                                                                                                                      | R/W |
|-----|--------|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | TMOIE  | Timeout Interrupt Request Enable                      | Timeout interrupt (TMOI) request is disabled.     Timeout interrupt (TMOI) request is enabled.                                   | R/W |
| b1  | ALIE   | Arbitration-Lost Interrupt Request<br>Enable          | Arbitration-lost interrupt (ALI) request is disabled.     Arbitration-lost interrupt (ALI) request is enabled.                   | R/W |
| b2  | STIE   | Start Condition Detection Interrupt<br>Request Enable | Start condition detection interrupt (STI) request is disabled.     Start condition detection interrupt (STI) request is enabled. | R/W |
| b3  | SPIE   | Stop Condition Detection Interrupt<br>Request Enable  | Stop condition detection interrupt (SPI) request is disabled.     Stop condition detection interrupt (SPI) request is enabled.   | R/W |
| b4  | NAKIE  | NACK Reception Interrupt Request<br>Enable            | NACK reception interrupt (NAKI) request is disabled.     NACK reception interrupt (NAKI) request is enabled.                     | R/W |
| b5  | RIE    | Receive Data Full Interrupt Request<br>Enable         | Receive data full interrupt (RXI) request is disabled.     Receive data full interrupt (RXI) request is enabled.                 | R/W |
| b6  | TEIE   | Transmit End Interrupt Request Enable                 | 0: Transmit end interrupt (TEI) request is disabled. 1: Transmit end interrupt (TEI) request is enabled.                         | R/W |
| b7  | TIE    | Transmit Data Empty Interrupt<br>Request Enable       | Transmit data empty interrupt (TXI) request is disabled.     Transmit data empty interrupt (TXI) request is enabled.             | R/W |

#### **TMOIE Bit (Timeout Interrupt Request Enable)**

This bit is used to enable or disable timeout interrupt (TMOI) requests when the ICSR2.TMOF flag is set to 1. A TMOI interrupt request is canceled by setting the TMOF flag or the TMOIE bit to 0.

### **ALIE Bit (Arbitration-Lost Interrupt Request Enable)**

This bit is used to enable or disable arbitration-lost interrupt (ALI) requests when the ICSR2.AL flag is set to 1. An ALI interrupt request is canceled by setting the AL flag or the ALIE bit to 0.

### STIE Bit (Start Condition Detection Interrupt Request Enable)

This bit is used to enable or disable start condition detection interrupt (STI) requests when the ICSR2.START flag is set to 1. An STI interrupt request is canceled by setting the START flag or the STIE bit to 0.

#### **SPIE Bit (Stop Condition Detection Interrupt Request Enable)**

This bit is used to enable or disable stop condition detection interrupt (SPI) requests when the ICSR2.STOP flag is set to 1. An SPI interrupt request is canceled by setting the STOP flag or the SPIE bit to 0.

### **NAKIE Bit (NACK Reception Interrupt Request Enable)**

This bit is used to enable or disable NACK reception interrupt (NAKI) requests when the ICSR2.NACKF flag is set to 1. An NAKI interrupt request is canceled by setting the NACKF flag or the NAKIE bit to 0.

#### RIE Bit (Receive Data Full Interrupt Request Enable)

This bit is used to enable or disable receive data full interrupt (RXI) requests when the ICSR2.RDRF flag is set to 1.



## **TEIE Bit (Transmit End Interrupt Request Enable)**

This bit is used to enable or disable transmit end interrupt (TEI) requests when the ICSR2.TEND flag is set to 1. An TEI interrupt request is canceled by setting the TEND flag or the TEIE bit to 0.

## TIE Bit (Transmit Data Empty Interrupt Request Enable)

This bit is used to enable or disable transmit data empty interrupt (TXI) requests when the ICSR2.TDRE flag is set to 1.



## 24.2.9 I<sup>2</sup>C-bus Status Register 1 (ICSR1)

Address(es): RIIC0.ICSR1 0008 8308h



| Bit | Symbol | Bit Name                            | Description                                                                                                                                                                                                                                                             | R/W         |
|-----|--------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| b0  | AAS0   | Slave Address 0 Detection Flag      | 0: Slave address 0 is not detected. 1: Slave address 0 is detected.                                                                                                                                                                                                     | R/(W)<br>*1 |
| b1  | AAS1   | Slave Address 1 Detection Flag      | 0: Slave address 1 is not detected. 1: Slave address 1 is detected.                                                                                                                                                                                                     | R/(W)<br>*1 |
| b2  | AAS2   | Slave Address 2 Detection Flag      | 0: Slave address 2 is not detected. 1: Slave address 2 is detected.                                                                                                                                                                                                     | R/(W)<br>*1 |
| b3  | GCA    | General Call Address Detection Flag | 0: General call address is not detected. 1: General call address is detected.                                                                                                                                                                                           | R/(W)<br>*1 |
| b4  | _      | Reserved                            | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                     | R/W         |
| b5  | DID    | Device-ID Address Detection Flag    | <ul> <li>0: Device-ID command is not detected.</li> <li>1: Device-ID command is detected.</li> <li>This bit is set to 1 when the first byte received immediately after a start condition is detected matches a value of (device ID (1111 100b) + 0 (write)).</li> </ul> |             |
| b6  | _      | Reserved                            | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                     | R/W         |
| b7  | НОА    | Host Address Detection Flag         | 0: Host address is not detected. 1: Host address is detected. • This bit is set to 1 when the received slave address matches the host address (0001 000b).                                                                                                              | R/(W)<br>*1 |

Note 1. Only 0 can be written to clear the flag.

#### AASy Flag (Slave Address y Detection Flag) (y = 0 to 2)

[Setting conditions]

For 7-bit address format: SARUy.FS bit = 0

• When the received slave address matches the SARLy.SVA[6:0] bits value with the ICSER.SARyE bit set to 1 (slave address y detection enabled)

This flag is set to 1 at the rising edge of the ninth SCL clock cycle in the first byte.

For 10-bit address format: SARUy.FS bit = 1

• When the received slave address matches a value of (11110b + SARUy.SVA[1:0] bits) and the following address matches the SARLy value with the ICSER.SARyE bit set to 1 (slave address y detection enabled)

This flag is set to 1 at the rising edge of the ninth SCL clock cycle in the second byte.

#### [Clearing conditions]

- When 0 is written to the AASy flag after reading the AASy flag to be 1
- When a stop condition is detected
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

For 7-bit address format: SARUy.FS bit = 0

• When the received slave address does not match the SARLy.SVA[6:0] bits value with the ICSER.SARyE bit set to 1 (slave address y detection enabled)

This flag is set to 0 at the rising edge of the ninth SCL clock cycle in the first byte.



For 10-bit address format: SARUy.FS bit = 1

- When the received slave address does not match a value of (11110b + SARUy.SVA[1:0] bits) with the ICSER.SARyE bit set to 1 (slave address y detection enabled)
  - This flag is set to 0 at the rising edge of the ninth SCL clock cycle in the first byte.
- When the received slave address matches a value of (11110b + SARUy.SVA[1:0] bits) and the following address does not match the SARLy value with the ICSER.SARyE bit set to 1 (slave address y detection enabled)

  This flag is set to 0 at the rising edge of the ninth SCL clock cycle in the second byte.

#### GCA Flag (General Call Address Detection Flag)

[Setting condition]

- When the received slave address matches the general call address (0000 000b + 0 (write)) with the ICSER.GCAE bit set to 1 (general call address detection is enabled)
  - This flag is set to 1 at the rising edge of the ninth SCL clock cycle in the first byte.

#### [Clearing conditions]

- When 0 is written to the GCA flag after reading GCA flag to be 1
- When a stop condition is detected
- When the received slave address does not match the general call address (0000 000b + 0 (write)) with the ICSER.GCAE bit set to 1 (general call address detection is enabled)
   This flag is set to 0 at the rising edge of the ninth SCL clock cycle in the first byte.
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

### **DID Flag (Device-ID Address Detection Flag)**

[Setting condition]

• When the first byte received immediately after a start condition or restart condition is detected matches a value of (device ID (1111 100b) + 0 (write)) with the ICSER.DIDE bit set to 1 (device-ID address detection is enabled)

This flag is set to 1 at the rising edge of the ninth SCL clock cycle in the first byte.

#### [Clearing conditions]

- When 0 is written to the DID flag after reading DID flag to be 1
- When a stop condition is detected
- When the first byte received immediately after a start condition or restart condition is detected does not match a value of (device ID (1111 100b)) with the ICSER.DIDE bit set to 1 (device-ID address detection is enabled)

  This flag is set to 0 at the rising edge of the ninth SCL clock cycle in the first byte.
- When the first byte received immediately after a start condition or restart condition is detected matches a value of (device ID (1111 100b) + 0 (write)) and the second byte does not match any of slave addresses 0 to 2 with the ICSER.DIDE bit set to 1 (device-ID address detection is enabled)
  - This flag is set to 0 at the rising edge of the ninth SCL clock cycle in the second byte.
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

#### **HOA Flag (Host Address Detection Flag)**

[Setting condition]

• When the received slave address matches the host address (0001 000b) with the ICSER.HOAE bit set to 1 (host address detection is enabled)

This flag is set to 1 at the rising edge of the ninth SCL clock cycle in the first byte.

### [Clearing conditions]

- When 0 is written to the HOA flag after reading HOA flag to be 1
- When a stop condition is detected
- When the received slave address does not match the host address (0001 000b) with the ICSER.HOAE bit set to 1



(host address detection is enabled)

This flag is set to 0 at the rising edge of the ninth SCL clock cycle in the first byte.

• When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset



## 24.2.10 I<sup>2</sup>C-bus Status Register 2 (ICSR2)

Address(es): RIIC0.ICSR2 0008 8309h



| Bit | Symbol | Bit Name                       | Description                                                                                  | R/W         |  |
|-----|--------|--------------------------------|----------------------------------------------------------------------------------------------|-------------|--|
| b0  | TMOF   | Timeout Detection Flag         | Timeout is not detected.     Timeout is detected.                                            | R/(W)<br>*1 |  |
| b1  | AL     | Arbitration-Lost Flag          | Arbitration is not lost.     Arbitration is lost.                                            | R/(W)<br>*1 |  |
| b2  | START  | Start Condition Detection Flag | Start condition is not detected.     Start condition is detected.                            | R/(W)<br>*1 |  |
| b3  | STOP   | Stop Condition Detection Flag  | Stop condition is not detected.     Stop condition is detected.                              | R/(W)<br>*1 |  |
| b4  | NACKF  | NACK Detection Flag            | 0: NACK is not detected. 1: NACK is detected.                                                | R/(W)<br>*1 |  |
| b5  | RDRF   | Receive Data Full Flag         | The ICDRR register contains no receive data.     The ICDRR register contains receive data.   | R/(W)<br>*1 |  |
| b6  | TEND   | Transmit End Flag              | Data is being transmitted.     Data has been transmitted.                                    | R/(W)<br>*1 |  |
| b7  | TDRE   | Transmit Data Empty Flag       | The ICDRT register contains transmit data.     The ICDRT register contains no transmit data. | R           |  |

Note 1. Only 0 can be written to clear the flag.

#### TMOF Flag (Timeout Detection Flag)

This flag is set to 1 when the RIIC recognizes timeout after the SCL0 line state remains unchanged for a certain period. [Setting condition]

When the SCL0 line state remains unchanged for the period specified by bits ICMR2.TMOH, TMOL, and TMOS
while the ICFER.TMOE bit is 1 (the timeout function is enabled) in master mode or in slave mode and the received
slave address matches.

[Clearing conditions]

- When 0 is written to the TMOF bit after reading TMOF = 1
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

#### **AL Flag (Arbitration-Lost Flag)**

This flag shows that bus mastership has been lost (loss in arbitration) due to a bus conflict or some other reason when a start condition is issued or an address and data are transmitted. The RIIC monitors the level on the SDA0 line during transmission and, if the level on the line does not match the value of the bit being output, sets the value of the AL flag to 1 to indicate that the bus is occupied by another device.

The RIIC can also set the flag to indicate the detection of loss of arbitration during NACK transmission in master mode or during data transmission in slave mode.

#### [Setting conditions]

When master arbitration-lost detection is enabled: ICFER.MALE = 1

- When the internal SDA output state does not match the SDA0 line level at the rising edge of SCL clock except for the ACK period during data (including slave address) transmission in master transmit mode (when the SDA0 line is driven low while the internal SDA output is at a high level (the SDA0 pin is in the high-impedance state))
- When a start condition is detected while the ICCR2.ST bit is 1 (start condition issuance request) or the internal SDA output state does not match the SDA0 line level
- When the ICCR2.ST bit is set to 1 (start condition issuance request) with the ICCR2.BBSY flag set to 1.

When NACK arbitration-lost detection is enabled: ICFER.NALE = 1

• When the internal SDA output state does not match the SDA0 line level at the rising edge of SCL clock in the ACK period during NACK transmission in receive mode

When slave arbitration-lost detection is enabled: ICFER.SALE = 1

• When the internal SDA output state does not match the SDA0 line level at the rising edge of SCL clock except for the ACK period during data transmission in slave transmit mode

[Clearing conditions]

- When 0 is written to the AL flag after reading AL = 1
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

Table 24.4 Relationship between Arbitration-Lost Generation Sources and Arbitration-Lost Enable Functions

|                | ICFER |      |    |                                  |                                                                                                                              |  |  |  |  |
|----------------|-------|------|----|----------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| MALE NALE SALE |       | SALE | AL | Error                            | Arbitration-Lost Generation Source                                                                                           |  |  |  |  |
| 1              | ×     | ×    | 1  | Start condition issuance error   | When internal SDA output state does not match SDA0 line level when a start condition is detected while the ICCR2.ST bit is 1 |  |  |  |  |
|                |       |      |    |                                  | When ICCR2.ST bit is set to 1 with ICCR2.BBSY flag set to 1                                                                  |  |  |  |  |
|                |       |      | 1  | Transmit data mismatch           | When transmit data (including slave address) does not match the bus state in master transmit mode                            |  |  |  |  |
| ×              | 1     | ×    | 1  | NACK<br>transmission<br>mismatch | When ACK is detected during transmission of NACK in master receive mode or slave receive mode                                |  |  |  |  |
| ×              | ×     | 1    | 1  | Transmit data mismatch           | When transmit data does not match the bus state in slave transmit mode                                                       |  |  |  |  |

x: Don't care

#### START Flag (Start Condition Detection Flag)

[Setting condition]

• When a start condition (or a restart condition) is detected

[Clearing conditions]

- When 0 is written to the START bit after reading START = 1
- When a stop condition is detected
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

#### **STOP Flag (Stop Condition Detection Flag)**

[Setting condition]

• When a stop condition is detected

[Clearing conditions]

- When 0 is written to the STOP bit after reading STOP = 1
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset



### **NACKF Flag (NACK Detection Flag)**

[Setting condition]

• When acknowledge is not received (NACK is received) from the receive device in transmit mode with the ICFER.NACKE bit set to 1 (transfer suspension enabled)

### [Clearing conditions]

- When 0 is written to the NACKF bit after reading NACKF = 1
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

Note: When the NACKF flag is set to 1, the RIIC suspends data transmission/reception. Writing to the ICDRT register in transmit mode or reading from the ICDRR register in receive mode with the NACKF flag set to 1 does not enable data transmit/receive operation. To restart data transmission/reception, set the NACKF flag to 0.

#### RDRF Flag (Receive Data Full Flag)

[Setting conditions]

- When receive data has been transferred from the ICDRS register to the ICDRR register

  This flag is set to 1 at the rising edge of the eighth or ninth SCL clock cycle (selected by the ICMR3.RDRFS bit)
- When the received slave address matches after a start condition (or a restart condition) is detected with the ICCR2.TRS bit set to 0

[Clearing conditions]

- When 0 is written to the RDRF bit after reading RDRF = 1
- When data is read from the ICDRR register
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

#### **TEND Flag (Transmit End Flag)**

[Setting condition]

• At the rising edge of the ninth SCL clock cycle while the TDRE flag is 1

#### [Clearing conditions]

- When 0 is written to the TEND bit after reading TEND = 1
- When data is written to the ICDRT register
- When a stop condition is detected
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

### **TDRE Flag (Transmit Data Empty Flag)**

[Setting conditions]

- When data has been transferred from the ICDRT register to the ICDRS register and the ICDRT register becomes empty
- When the ICCR2.TRS bit is set to 1
- When the received slave address matches while the TRS bit is 1

[Clearing conditions]

- When data is written to the ICDRT register
- When the ICCR2.TRS bit is set to 0
- When 1 is written to the ICCR1.IICRST bit to apply an RIIC reset or an internal reset

Note: When the NACKF flag is set to 1 while the ICFER.NACKE bit is 1, the RIIC suspends data transmission/ reception. Here, if the TDRE flag is 0 (next transmit data has been written), data is transferred to the ICDRS register and the ICDRT register becomes empty at the rising edge of the ninth clock cycle, but the TDRE flag is not set to 1.



## 24.2.11 Slave Address Register Ly (SARLy) (y = 0 to 2)

Address(es): RIIC0.SARL0 0008 830Ah, RIIC0.SARL1 0008 830Ch, RIIC0.SARL2 0008 830Eh



| Bit      | Symbol   | Bit Name                                | Description             | R/W |
|----------|----------|-----------------------------------------|-------------------------|-----|
| b0       | SVA0     | 10-Bit Address LSB                      | A slave address is set. | R/W |
| b7 to b1 | SVA[6:0] | 7-Bit Address/10-Bit Address Lower Bits | A slave address is set. | R/W |

#### SVA0 Bit (10-Bit Address LSB)

When the 10-bit address format is selected (SARUy.FS bit is 1), this bit functions as the LSB of a 10-bit address and forms the lower 8 bits of a 10-bit address in combination with the SVA[6:0] bits.

When the ICSER.SARyE bit is set to 1 (SARLy and SARUy enabled) and the SARUy.FS bit is 1, this bit is valid. While the SARUy.FS bit or SARyE bit is 0, the setting of this bit is ignored.

### SVA[6:0] Bits (7-Bit Address/10-Bit Address Lower Bits)

When the 7-bit address format is selected (SARUy.FS bit is 0), these bits function as a 7-bit address. When the 10-bit address format is selected (SARUy.FS bit is 1), these bits function as the lower 8 bits of a 10-bit address in combination with the SVA0 bit.

While the ICSER.SARyE bit is 0, the setting of these bits is ignored.

## 24.2.12 Slave Address Register Uy (SARUy) (y = 0 to 2)

Address(es): RIIC0.SARU0 0008 830Bh, RIIC0.SARU1 0008 830Dh, RIIC0.SARU2 0008 830Fh



| Bit      | Symbol   | Bit Name                           | Description                                                                                                  | R/W |
|----------|----------|------------------------------------|--------------------------------------------------------------------------------------------------------------|-----|
| b0       | FS       | 7-Bit/10-Bit Address Format Select | <ul><li>0: The 7-bit address format is selected.</li><li>1: The 10-bit address format is selected.</li></ul> | R/W |
| b2, b1   | SVA[1:0] | 10-Bit Address Upper Bits          | A slave address is set.                                                                                      | R/W |
| b7 to b3 | _        | Reserved                           | These bits are read as 0. The write value should be 0.                                                       | R/W |

### FS Bit (7-Bit/10-Bit Address Format Select)

This bit is used to select 7-bit address or 10-bit address for slave address y (in registers SARLy and SARUy). When the ICSER.SARyE bit is set to 1 (registers SARLy and SARUy enabled) and the SARUy.FS bit is 0, the 7-bit address format is selected for slave address y, the SARLy.SVA[6:0] bits setting is valid, and the settings of the SVA[1:0] bits and the SARLy.SVA0 bit are ignored.

When the ICSER.SARyE bit is set to 1 (registers SARLy and SARUy enabled) and the SARUy.FS bit is 1, the 10-bit address format is selected for slave address y and the settings of the SVA[1:0] bits and SARLy are valid. While the ICSER.SARyE bit is 0 (registers SARLy and SARUy disabled), the setting of the SARUy.FS bit is invalid.

#### SVA[1:0] Bits (10-Bit Address Upper Bits)

When the 10-bit address format is selected (FS = 1), these bits function as the upper 2 bits of a 10-bit address. When the ICSER.SARyE bit is set to 1 (SARLy and SARUy enabled) and the SARUy.FS bit is 1, these bits are valid. While the SARUy.FS bit or SARyE bit is 0, the setting of these bits is ignored.

## 24.2.13 I<sup>2</sup>C-bus Bit Rate Low-Level Register (ICBRL)

Address(es): RIIC0.ICBRL 0008 8310h



| Bit      | Symbol   | Bit Name                  | Description                                            | R/W |
|----------|----------|---------------------------|--------------------------------------------------------|-----|
| b4 to b0 | BRL[4:0] | Bit Rate Low-Level Period | Low-level period of SCL clock                          | R/W |
| b7 to b5 |          | Reserved                  | These bits are read as 1. The write value should be 1. | R/W |

ICBRL is a 5-bit register to set the low-level period of SCL clock.

It also works to generate the data setup time for automatic SCL low-hold operation (refer to section 24.8, Automatic Low-Hold Function for SCL); when the RIIC is used only in slave mode, this register needs to be set to a value longer than the data setup time\*1.

ICBRL counts the low-level period with the internal reference clock (IIC $\phi$ ) specified by the ICMR1.CKS[2:0] bits. If the digital noise filter is enabled (the ICFER.NFE bit is 1), set the ICBRL register to a value at least one greater than the number of stages in the noise filter. Regarding the number of stages in the noise filter, see the description of the ICMR3.NF[1:0] bits.

Note 1. Data setup time (tSU: DAT)

250 ns (up to 100 kbps: Standard-mode (Sm)) 100 ns (up to 400 kbps: Fast-mode (Fm))

## 24.2.14 I<sup>2</sup>C-bus Bit Rate High-Level Register (ICBRH)

Address(es): RIIC0.ICBRH 0008 8311h



| Bit      | Symbol   | Bit Name                   | Description                                            | R/W |
|----------|----------|----------------------------|--------------------------------------------------------|-----|
| b4 to b0 | BRH[4:0] | Bit Rate High-Level Period | High-level period of SCL clock                         | R/W |
| b7 to b5 | _        | Reserved                   | These bits are read as 1. The write value should be 1. | R/W |

ICBRH is a 5-bit register to set the high-level period of SCL clock. ICBRH is valid in master mode. If the RIIC is used only in slave mode, this register need not to set the high-level period.

ICBRH counts the high-level period with the internal reference clock (IIC $\phi$ ) specified by the ICMR1.CKS[2:0] bits. If the digital noise filter is enabled (the ICFER.NFE bit is 1), set the ICBRH register to a value at least one greater than the number of stages in the noise filter. Regarding the number of stages in the noise filter, see the description of the ICMR3.NF[1:0] bits.

The I<sup>2</sup>C transfer rate and the SCL clock duty are calculated using the following expression.

 $\begin{aligned} & \text{Transfer rate} = 1 / \left\{ \left[ \left( ICBRH + 1 \right) + \left( ICBRL + 1 \right) \right] / \left| IIC\phi^{*1} + SCL0 \right| \text{ line rising time [tr]} + SCL0 \right| \text{ line falling time [tf]} \right\} \\ & \text{Duty cycle} = \left\{ SCL0 \right| \text{ line rising time [tr]}^{*2} + \left( ICBRH + 1 \right) / \left| IIC\phi \right\} / \left\{ SCL0 \right| \text{ line falling time [tf]}^{*2} + \left( ICBRL + 1 \right) / \left| IIC\phi \right\} \end{aligned}$ 

Note 1.  $IIC_{\phi} = PCLK \times Division ratio$ 

Note 2. The SCL0 line rising time [tr] and SCL0 line falling time [tf] depend on the total bus line capacitance [Cb] and the pull-up resistor [Rp]. For details, see the I<sup>2</sup>C-bus specification from NXP Semiconductors.

Table 24.5 lists examples of ICBRH/ICBRL settings.

Table 24.5 Examples of ICBRH/ICBRL Settings for Transfer Rate

| Transfer<br>Rate | Operating Frequency PCLK (MHz) |          |          |          |          |          |          |          |          |
|------------------|--------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|
|                  | 8                              |          |          | 10       |          |          | 12.5     |          |          |
| (kbps)           | CKS[2:0]                       | ICBRH    | ICBRL    | CKS[2:0] | ICBRH    | ICBRL    | CKS[2:0] | ICBRH    | ICBRL    |
| 10               | 100b                           | 22 (F6h) | 25 (F9h) | 101b     | 13 (EDh) | 15 (EFh) | 101b     | 16 (F0h) | 20 (F4h) |
| 50               | 010b                           | 16 (F0h) | 19 (F3h) | 010b     | 21 (F5h) | 24 (F8h) | 011b     | 12 (ECh) | 15 (EFh) |
| 100              | 001b                           | 15 (EFh) | 18 (F2h) | 001b     | 19 (F3h) | 23 (F7h) | 001b     | 24 (F8h) | 29 (FDh) |
| 400              | 000b                           | 4 (E4h)  | 10 (EAh) | 000b     | 5 (E5h)  | 12 (ECh) | 000b     | 7 (E7h)  | 16 (F0h) |

|                  | Operating Frequency PCLK (MHz) |          |          |          |          |          |          |          |          |
|------------------|--------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|
| Transfer<br>Rate | 16                             |          |          | 20       |          |          | 25       |          |          |
| (kbps)           | CKS[2:0]                       | ICBRH    | ICBRL    | CKS[2:0] | ICBRH    | ICBRL    | CKS[2:0] | ICBRH    | ICBRL    |
| 10               | 101b                           | 22 (F6h) | 25 (F9h) | 110b     | 13 (EDh) | 15 (EFh) | 110b     | 16 (F0h) | 20 (F4h) |
| 50               | 011b                           | 16 (F0h) | 19 (F3h) | 011b     | 21 (F5h) | 24 (F8h) | 100b     | 12 (ECh) | 15 (EFh) |
| 100              | 010b                           | 15 (EFh) | 18 (F2h) | 010b     | 19 (F3h) | 23 (F7h) | 010b     | 24 (F8h) | 29 (FDh) |
| 400              | 000b                           | 9 (E9h)  | 20 (F4h) | 000b     | 11 (EBh) | 25 (F9h) | 001b     | 7 (E7h)  | 16 (F0h) |

| <u> </u>         | Operating Frequency PCLK (MHz) |          |          |          |          |          |  |  |  |  |
|------------------|--------------------------------|----------|----------|----------|----------|----------|--|--|--|--|
| Transfer<br>Rate |                                | 30       |          | 32       |          |          |  |  |  |  |
| (kbps)           | CKS[2:0]                       | ICBRH    | ICBRL    | CKS[2:0] | ICBRH    | ICBRL    |  |  |  |  |
| 10               | 110b                           | 20 (F4h) | 24 (F8h) | 110b     | 22 (F6h) | 25 (F9h) |  |  |  |  |
| 50               | 100b                           | 15 (EFh) | 18 (F2h) | 100b     | 16 (F0h) | 19 (F3h) |  |  |  |  |
| 100              | 010b                           | 2 (E2h)  | 3 (E3h)  | 011b     | 15 (EFh) | 18 (F2h) |  |  |  |  |
| 400              | 001b                           | 8 (E8h)  | 19 (F3h) | 001b     | 9 (E9h)  | 20 (F4h) |  |  |  |  |

Note: ICBRH/ICBRL settings in these tables are calculated using the following values:

SCL0 line rising time (tr): 100 kbps or less (Sm): 1000 ns, 400 kbps or less (Fm): 300 ns

SCL0 line falling time (tf): 400 kbps or less (Sm/Fm): 300 ns

For the specified values of SCL0 line rising time (tr) and SCL0 line falling time (tf), see the I<sup>2</sup>C-bus specification from NXP Semiconductors.

## 24.2.15 I<sup>2</sup>C-bus Transmit Data Register (ICDRT)

Address(es): RIIC0.ICDRT 0008 8312h



When the ICDRT register detects a space in the  $I^2C$ -bus shift register (ICDRS), it transfers the transmit data that has been written to the ICDRT register to the ICDRS register and starts transmitting data in transmit mode.

The double-buffer structure of the ICDRT register and the ICDRS register allows continuous transmit operation if the next transmit data has been written to the ICDRT register while the ICDRS register data is being transmitted. the ICDRT register can always be read and written. Write transmit data to the ICDRT register once when a transmit data empty interrupt (TXI) request is generated.

## 24.2.16 I<sup>2</sup>C-bus Receive Data Register (ICDRR)

Address(es): RIIC0.ICDRR 0008 8313h



When 1 byte of data has been received, the received data is transferred from the I<sup>2</sup>C-bus shift register (ICDRS) to the ICDRR register to enable the next data to be received.

The double-buffer structure of the ICDRS register and the ICDRR register allows continuous receive operation if the received data has been read from the ICDRR register while the ICDRS register is receiving data.

the ICDRR register cannot be written. Read data from the ICDRR register once when a receive data full interrupt (RXI) request is generated.

If the ICDRR register receives the next receive data before the current data is read from the ICDRR register (while the ICSR2.RDRF flag is 1), the RIIC automatically holds the SCL clock low one cycle before the RDRF flag is set to 1 next.

## 24.2.17 I<sup>2</sup>C-bus Shift Register (ICDRS)



ICDRS register is an 8-bit shift register to transmit and receive data.

During transmission, transmit data is transferred from the ICDRT register to the ICDRS register and is sent from the SDA0 pin. During reception, data is transferred from the ICDRS register to the ICDRR register after 1 byte of data has been received.

ICDRS register cannot be accessed directly.

# 24.2.18 Timeout Internal Counter (TMOCNTL/TMOCNTU)

Address(es): RIIC0.TMOCNTL 0008 830Ah, RIIC0.TMOCNTU 0008 830Bh

• TMOS = 0 (Long mode)



• TMOS = 1 (Short mode)



Note: These registers are assigned to the same addresses as those of registers SARL0 and SARU0. Set these registers after setting the ICMR2.TMWE bit to 1.

The timeout internal counter (TMOCNTL/TMOCNTU) is an internal counter for the timeout detection. The timeout internal counter functions as a 16-bit counter in long mode and as a 14-bit counter in short mode. When the counter overflows, the RIIC detects a timeout.

Registers TMOCNTL and TMOCNTU are assigned to the same addresses as those of registers SARL0 and SARU0. Registers TMOCNTL and TMOCNTU are selected when the ICMR2.TMWE bit is 1, and registers SARL0 and SARU0 are selected when the ICMR2.TMWE bit is 0.

Registers TMOCNTL and TMOCNTU are write-only and cannot be read.

The timeout internal counter (TMOCNTL/TMOCNTU) is cleared (TMOCNTL = 00h, TMOCNTU = 00h) after a reset, when ICCR1.IICRST is set to 1, or when the counter clearing conditions specified by bits TMOH and TMOL in the ICMR2 register (SCL rising edge/falling edge detection) are met while the ICFER.TMOE bit is 1 and the ICMR1.CKS[2:0] bits are 000b (PCLK/1).

The timeout internal counter is not automatically cleared when the ICMR1.CKS[2:0] bits are not 000b (PCLK/1). Therefore, write 00h to clear the TMOCNTL and TMOCNTU counters if necessary.

The TMOCNTL and TMOCNTU counters can be accessed as 16-bit registers in 16-bit units.

For 16-bit access, access the address shown in the table below.

Table 24.6 Register Allocation for 16-Bit Access

| Address    | Upper 8 Bits  | Lower 8 Bits  |
|------------|---------------|---------------|
| 0008 830Ah | RIIC0.TMOCNTU | RIIC0.TMOCNTL |

# 24.3 Operation

#### 24.3.1 Communication Data Format

The I<sup>2</sup>C-bus format consists of 8-bit data and 1-bit acknowledge. The first byte following a start condition or restart condition is an address byte used to specify a slave device with which the master device communicates. The specified slave is valid until a new slave is specified or a stop condition is issued.

Figure 24.3 shows the I<sup>2</sup>C-bus format, and Figure 24.4 shows the I<sup>2</sup>C-bus timing.



Figure 24.3 I<sup>2</sup>C-bus Format



Figure 24.4 I<sup>2</sup>C-bus Timing (SLA = 7 Bits)

- S: Start condition. The master device drives the SDA0 line low from high level while the SCL0 line is at a high level.
- SLA: Slave address, by which the master device selects a slave device.
- R/W#: Indicates the direction of data transfer: from the slave device to the master device when R/W is 1, or from the master device to the slave device when R/W is 0.
- A: Acknowledge. The receive device drives the SDA0 line low. (In master transmit mode, the slave device returns acknowledge. In master receive mode, the master device returns acknowledge.)
- A#: Not Acknowledge. The receive device drives the SDA0 line high.
- Sr: Restart condition. The master device drives the SDA0 line low from the high level after the setup time has elapsed with the SCL0 line at the high level.
- DATA: Transmitted or received data
- P: Stop condition. The master device drives the SDA0 line high from low level while the SCL0 line is at a high level.

# 24.3.2 Initial Settings

Before starting data transmission and reception, initialize the RIIC according to the procedure in Figure 24.5. Set the ICCR1.ICE bit to 1 (internal reset) after setting the ICCR1.IICRST bit to 1 (RIIC reset) with the ICCR1.ICE bit set to 0 (SCL0 and SDA0 pins in inactive state). This initializes the various flags and internal state of the ICSR1 register. After that, set registers SARLy, SARUy, ICSER, ICMR1, ICBRH, and ICBRL (y = 0 to 2), and set the other registers as necessary (for initial settings of the RIIC, see Figure 24.5). When the necessary register settings have been completed, set the ICCR1.IICRST bit to 0 (releases the RIIC reset). This step is not necessary if initialization of the RIIC has already been completed.



Figure 24.5 Example of RIIC Initialization Flowchart

#### 24.3.3 Master Transmit Operation

In master transmit operation, the RIIC outputs the SCL clock and transmitted data signals as the master device, and the slave device returns acknowledgments. Figure 24.6 shows an example of usage of master transmission and Figure 24.7 to Figure 24.9 show the timing of operations in master transmission.

The following describes the procedure and operations for master transmission.

- (1) Initial settings. For details, refer to section 24.3.2, Initial Settings.
- (2) Read the ICCR2.BBSY flag to check that the bus is open, and then set the ICCR2.ST bit to 1 (start condition issuance request). Upon receiving the request, the RIIC issues a start condition. At the same time, the BBSY flag and the ICSR2.START flag are automatically set to 1 and the ST bit is automatically set to 0. At this time, if the start condition is detected and the internal levels for the SDA output state and the levels on the SDA0 line have matched while the ST bit is 1, the RIIC recognizes that issuing of the start condition as requested by the ST bit has been successfully completed, and bits MST and TRS in the ICCR2 register are automatically set to 1, placing the RIIC in master transmit mode. The ICSR2.TDRE flag is also automatically set to 1 in response to setting of the TRS bit to 1.
- (3) Check that the ICSR2.TDRE flag is 1, and then write the value for transmission (the slave address and the R/W# bit) to the ICDRT register. Once the data for transmission are written to the ICDRT register, the TDRE flag is automatically set to 0, the data are transferred from the ICDRT register to the ICDRS register, and the TDRE flag is again set to 1. After the byte containing the slave address and R/W# bit has been transmitted, the value of the TRS bit is automatically updated to select master transmit or master receive mode in accord with the value of the transmitted R/W# bit. If the value of the R/W# bit was 0, the RIIC continues in master transmit mode.

  Because the ICSR2.NACKF flag being 1 at this time indicates that no slave device recognized the address or there was an error in communications, write 1 to the ICCR2.SP bit to issue a stop condition.

  For data transmission with an address in the 10-bit format, start by writing 1111 0b, the 2 higher-order bits of the slave address, and W to the ICDRT register as the first address transmission. Then, as the second address transmission, write the 8 lower-order bits of the slave address to the ICDRT register.
- (4) After confirming that the ICSR2.TDRE flag is 1, write the data for transmission to the ICDRT register. The RIIC automatically holds the SCL0 line low until the data for transmission are ready or a stop condition is issued.
- (5) After all bytes of data for transmission have been written to the ICDRT register, wait until the value of the ICSR2.TEND flag returns to 1, and then set the ICCR2.SP bit to 1 (stop condition issuance request). Upon receiving a stop condition issuance request, the RIIC issues the stop condition.
- (6) Upon detecting the stop condition, the RIIC automatically sets bits MST and TRS in the ICCR2 register to 00b and enters slave receive mode. Furthermore, it automatically sets the TDRE and TEND flags to 0, and sets the ICSR2.STOP flag to 1.
- (7) After checking that the ICSR2.STOP flag is 1, set the ICSR2.NACKF and STOP flags to 0 for the next transfer operation.



Figure 24.6 Example of Master Transmission Flowchart



Figure 24.7 Master Transmit Operation Timing (1) (7-Bit Address Format)



Figure 24.8 Master Transmit Operation Timing (2) (10-Bit Address Format)



Figure 24.9 Master Transmit Operation Timing (3)

# 24.3.4 Master Receive Operation

In master receive operation, the RIIC as a master device outputs the SCL clock, receives data from the slave device, and returns acknowledgments. Because the RIIC must start by sending a slave address to the corresponding slave device, this part of the procedure is performed in master transmit mode, but the subsequent steps are in master receive mode. Figure 24.10 and Figure 24.11 show examples of usage of master reception (7-bit address format) and Figure 24.12 to Figure 24.14 show the timing of operations in master reception.

The following describes the procedure and operations for master reception.

- (1) Initial settings. For details, refer to section 24.3.2, Initial Settings.
- (2) Read the ICCR2.BBSY flag to check that the bus is open, and then set the ICCR2.ST bit to 1 (start condition issuance request). Upon receiving the request, the RIIC issues a start condition. When the RIIC detects the start condition, the BBSY flag and the ICSR2.START flag are automatically set to 1 and the ST bit is automatically set to 0. At this time, if the start condition is detected and the levels for the SDA output and the levels on the SDA0 line have matched while the ST bit is 1, the RIIC recognizes that issuing of the start condition as requested by the ST bit has been successfully completed, and bits MST and TRS in the ICCR2 register are automatically set to 1, placing the RIIC in master transmit mode. The ICSR2.TDRE flag is also automatically set to 1 in response to setting of the TRS bit to 1.
- (3) Check that the ICSR2.TDRE flag is 1, and then write the value for transmission (the first byte indicates the slave address and value of the R/W# bit) to the ICDRT register. Once the data for transmission are written to the ICDRT register, the TDRE flag is automatically set to 0, the data are transferred from the ICDRT register to the ICDRS register, and the TDRE flag is again set to 1. Once the byte containing the slave address and R/W# bit has been transmitted, the value of the ICCR2.TRS bit is automatically updated to select transmit or receive mode in accord with the value of the transmitted R/W# bit. If the value of the R/W# bit was 1, the TRS bit is set to 0 on the rising edge of the ninth cycle of SCL clock, placing the RIIC in master receive mode. At this time, the TDRE flag is set to 0 and the ICSR2.RDRF flag is automatically set to 1.

- Because the ICSR2.NACKF flag being 1 at this time indicates that no slave device recognized the address or there was an error in communications, write 1 to the ICCR2.SP bit to issue a stop condition.
- For master reception from a device with a 10-bit address, start by using master transmission to issue the 10-bit address, and then issue a restart condition. After that, transmitting 1111 0b, the two higher-order bits of the slave address, and the R bit places the RIIC in master receive mode.
- (4) Dummy read the ICDRR register after confirming that the ICSR2.RDRF flag is 1; this makes the RIIC start output of the SCL clock and start data reception.
- (5) After 1 byte of data has been received, the ICSR2.RDRF flag is set to 1 on the rising edge of the eighth or ninth cycle of SCL clock (the clock signal) as selected by the ICMR3.RDRFS bit. Reading the ICDRR register at this time will produce the received data, and the RDRF flag is automatically set to 0 at the same time. Furthermore, the value of the acknowledgment field received during the ninth cycle of SCL clock is returned as the value set in the ICMR3.ACKBT bit. Furthermore, if the next byte to be received is the next to last byte, set the ICMR3.WAIT bit to 1 (for wait insertion) before reading the ICDRR register (containing the second byte from last). As well as enabling NACK output even in the case of delays in processing to set the ICMR3.ACKBT bit to 1 (NACK) in step (6), due to other interrupts, etc., this fixes the SCL0 line to the low level on the falling edge of the ninth clock cycle in reception of the last byte, so the state is such that issuing a stop condition is possible.
- (6) When the ICMR3.RDRFS bit is 0 and the slave device must be notified that it is to end transfer for data reception after transfer of the next (final) byte, set the ICMR3.ACKBT bit to 1 (NACK).
- (7) After reading the byte before last from the ICDRR register, if the value of the ICSR2.RDRF flag is confirmed to be 1, write 1 to the ICCR2.SP bit (stop condition issuance request) and then read the last byte from the ICDRR register. When the ICDRR register is read, the RIIC is released from the wait state and issues the stop condition after low-level output in the ninth clock cycle is completed or the SCL0 line is released from the low-hold state.
- (8) Upon detecting the stop condition, the RIIC automatically sets bits MST and TRS in the ICCR2 register to 00b and enters slave receive mode. Furthermore, detection of the stop condition leads to setting of the ICSR2.STOP flag to 1.
- (9) After checking that the ICSR2.STOP flag is 1, set the ICSR2.NACKF and STOP flags to 0 for the next transfer operation.



Figure 24.10 Example of Master Reception (7-Bit Address Format, 1 or 2 bytes)



Figure 24.11 Example of Master Reception (7-Bit Address Format, 3 Bytes or More)



Figure 24.12 Master Receive Operation Timing (1) (7-Bit Address Format, When RDRFS bit is 0)



Figure 24.13 Master Receive Operation Timing (2) (10-Bit Address Format, When RDRFS bit is 0)



Figure 24.14 Master Receive Operation Timing (3) (When RDRFS bit is 0)

#### 24.3.5 Slave Transmit Operation

In slave transmit operation, the master device outputs the SCL clock, the RIIC transmits data as a slave device, and the master device returns acknowledgments.

Figure 24.15 shows an example of usage of slave transmission and Figure 24.16 and Figure 24.17 show the timing of operations in slave transmission.

The following describes the procedure and operations for slave transmission.

- (1) Initial settings. For details, refer to section 24.3.2, Initial Settings.

  After initial settings, the RIIC will stay in the standby state until it receives a slave address that it matches.
- (2) After receiving a matching slave address, the RIIC sets one of the corresponding bits ICSR1.HOA, GCA, and AASy (y = 0 to 2) to 1 on the rising edge of the ninth cycle of SCL clock (the clock signal) and outputs the value set in the ICMR3.ACKBT bit to the acknowledge bit on the ninth cycle of SCL clock. If the value of the R/W# bit that was also received at this time is 1, the RIIC automatically places itself in slave transmit mode by setting both the ICCR2.TRS bit and the ICSR2.TDRE flag to 1.
- (3) After the ICSR2.TDRE flag is confirmed to be 1, write the data for transmission to the ICDRT register. At this time, if the RIIC receives no acknowledge from the master device (receives an NACK signal) while the ICFER.NACKE bit is 1, the RIIC suspends transfer of the next data.
- (4) Wait until the ICSR2.TEND flag is set to 1 while the ICSR2.TDRE flag is 1, after the ICSR2.NACKF flag is set to 1 or the last byte for transmission is written to the ICDRT register. When the ICSR2.NACKF flag or the TEND flag is 1, the RIIC drives the SCL0 line low on the ninth falling edge of SCL clock.
- (5) When the ICSR2.NACKF flag or the ICSR2.TEND flag is 1, dummy read the ICDRR register to complete the processing. This releases the SCL0 line.
- (6) Upon detecting the stop condition, the RIIC automatically sets bits ICSR1.HOA, GCA, and AASy (y = 0 to 2), flags ICSR2.TDRE and TEND, and the ICCR2.TRS bit to 0, and enters slave receive mode.
- (7) After checking that the ICSR2.STOP flag is 1, set the ICSR2.NACKF and STOP flags to 0 for the next transfer operation.



Figure 24.15 Example of Slave Transmission Flowchart



Figure 24.16 Slave Transmit Operation Timing (1) (7-Bit Address Format)



Figure 24.17 Slave Transmit Operation Timing (2)

#### 24.3.6 Slave Receive Operation

In slave receive operation, the master device outputs the SCL clock and transmit data, and the RIIC returns acknowledgments as a slave device.

Figure 24.18 shows an example of usage of slave reception and Figure 24.19 and Figure 24.20 show the timing of operations in slave reception.

The following describes the procedure and operations for slave reception.

- (1) Initial settings. For details, refer to section 24.3.2, Initial Settings.

  After initial settings, the RIIC will stay in the standby state until it receives a slave address that it matches.
- (2) After receiving a matching slave address, the RIIC sets one of the corresponding bits ICSR1.HOA, GCA, and AASy (y = 0 to 2) to 1 on the rising edge of the ninth cycle of SCL clock (the clock signal) and outputs the value set in the ICMR3.ACKBT bit to the acknowledge bit on the ninth cycle of SCL clock. If the value of the R/W# bit that was also received at this time is 0, the RIIC continues to place itself in slave receive mode and sets the ICSR2.RDRF flag to 1.
- (3) After the ICSR2.STOP flag is confirmed to be 0 and the ICSR2.RDRF flag to be 1, dummy read the ICDRR register (the dummy value consists of the slave address and R/W# bit when the 7-bit address format is selected, or the lower 8 bits when the 10-bit address format is selected).
- (4) When the ICDRR register is read, the RIIC automatically sets the ICSR2.RDRF flag to 0. If reading of the ICDRR register is delayed and a next byte is received while the RDRF flag is still set to 1, the RIIC holds the SCL0 line low from one SCL cycle before the timing with which RDRF should be set. In this case, reading the ICDRR register releases the SCL0 line from being held at the low level.
  - When the ICSR2.STOP flag is 1 and the ICSR2.RDRF flag is also 1, read the ICDRR register until all the data is completely received.
- (5) Upon detecting the stop condition, the RIIC automatically clears bits ICSR1.HOA, GCA, and AASy (y = 0 to 2) to 0.
- (6) After checking that the ICSR2.STOP flag is 1, set the ICSR2.STOP flag to 0 for the next transfer operation.



Figure 24.18 Example of Slave Reception Flowchart



Figure 24.19 Slave Receive Operation Timing (1) (7-Bit Address Format, when RDRFS bit is 0)



Figure 24.20 Slave Receive Operation Timing (2) (when RDRFS bit is 0)

# 24.4 SCL Synchronization Circuit

In generation of the SCL clock, the RIIC starts counting out the value for width at high level specified in the ICBRH register when it detects a rising edge on the SCL0 line and drives the SCL0 line low once counting of the width at high level is complete. When the RIIC detects the falling edge of the SCL0 line, it starts counting out the width at low level period specified in the ICBRL register, and then stops driving the SCL0 line (releases the line) once counting of the width at low level is complete. The SCL clock is thus generated.

If multiple master devices are connected to the I<sup>2</sup>C-bus, a collision of SCL signals may arise due to contention with another master device. In such cases, the master devices have to synchronize their SCL signals. Because this synchronization of SCL signals must be bit by bit, the RIIC is equipped with a facility (the SCL synchronization circuit) to obtain bit-by-bit synchronization of the SCL clock signals by monitoring the SCL0 line while in master mode. When the RIIC has detected a rising edge on the SCL0 line and thus started counting out the width at high level specified in the ICBRH register, and the level on the SCL0 line falls because an SCL signal is being generated by another master device, the RIIC stops counting when it detects the falling edge, drives the level on the SCL0 line low, and starts counting out the width at low level specified in the ICBRL register. When the RIIC finishes counting out the width at low level, it stops driving the SCL0 line to the low level (i.e. releases the line). At this time, if the width at low level of the SCL clock signal from the other master device is longer than the width at low level set in the RIIC, the width at low level of the SCL signal will be extended. Once the width at low level for the other master device has ended, the SCL signal rises because the SCL0 line has been released. When the RIIC finishes outputting the low-level period of the SCL clock, the SCL0 line is released and the SCL clock rises. That is, in cases of contention of SCL signals from more than one master, the width at high level of the SCL signal is synchronized with that of the clock having the narrower width, and the width at low level of the SCL signal is synchronized with that of the clock having the broader width. However, such synchronization of the SCL signal is only enabled when the ICFER.SCLE bit is set to 1.



Figure 24.21 Generation and Synchronization of the SCL Signal from the RIIC

# 24.5 SDA Output Delay Function

The RIIC module incorporates a function for delaying output on the SDA line. The delay can be applied to all output (issuing of the start, restart, and stop conditions, data, and the ACK and NACK signals) on the SDA line.

With the SDA output delay function, SDA output is delayed from detection of a falling edge of the SCL signal to ensure that the SDA signal is output within the interval over which the SCL clock is at the low level. Doing this leads to usage with the aim of preventing erroneous operation of communications devices, with the aim of satisfying the 300-ns (min.) data-hold time requirement of the SMBus specification.

The output delay function is enabled by setting the ICMR2.SDDL[2:0] bits to any value other than 000b, and disabled by setting the same bits to 000b.

While the SDA output delay function is enabled (i.e. while the ICMR2.SDDL[2:0] bits are set to any value other than 000b), the ICMR2.DLCS bit selects the clock source for counting by the SDA output delay counter as the internal base clock (IIC $\phi$ ) for the RIIC module or as a clock signal derived by dividing the frequency of the internal base clock by two (IIC $\phi$ /2). The counter counts the number of cycles set in the ICMR2.SDDL[2:0] bits. After counting of the set number of cycles of delay is completed, the RIIC module places the required output (start, restart, or stop condition, data, or an ACK or NACK signal) on the SDA line.



Figure 24.22 SDA Output Delay Function

#### 24.6 Digital Noise Filter Circuit

The states of the SCL0 and SDA0 pins are conveyed to the internal circuitry through analog noise-filter and digital noise-filter circuits. Figure 24.23 is a block diagram of the digital noise-filter circuit.

The on-chip digital noise-filter circuit of the RIIC consists of four flip-flop circuit stages connected in series and a match-detection circuit.

The number of effective stages in the digital noise filter is selected by the ICMR3.NF[1:0] bits. The selected number of effective stages determines the noise-filtering capability as a period from one to four IIC $\phi$  cycles.

The input signal to the SCL0 pin (or SDA0 pin) is sampled on falling edges of the IIC $\phi$  signal. When the input signal level matches the output level of the number of effective flip-flop circuit stages as selected by the ICMR3.NF[1:0] bits, the signal level is conveyed to the subsequent stage. If the signal levels do not match, the previous value is retained. If the ratio between the frequency of the internal operating clock (PCLK) and the transfer rate is small (e.g. data transfer at 400 kbps with PCLK = 4 MHz), the characteristics of the digital noise filter may lead to the elimination of needed signals as noise. In such cases, it is possible to disable the digital noise-filter circuit (by setting the ICFER.NFE bit to 0) and use only the analog noise filter circuit.



Figure 24.23 Block Diagram of Digital Noise Filter Circuit

#### 24.7 Address Match Detection

The RIIC can set three unique slave addresses in addition to the general call address and host address, and also can set 7-bit or 10-bit slave addresses.

#### 24.7.1 Slave-Address Match Detection

The RIIC can set three unique slave addresses, and has a slave address detection function for each unique slave address. When the ICSER.SARyE bit (y = 0 to 2) is set to 1, the slave addresses set in registers SARUy and SARLy (y = 0 to 2) can be detected.

When the RIIC detects a match of the set slave address, the corresponding ICSR1.AASy flag (y = 0 to 2) is set to 1 at the rising edge of the ninth SCL clock cycle, and the ICSR2.RDRF flag or the ICSR2.TDRE flag is set to 1 by the following R/W# bit. This causes a receive data full interrupt (RXI) or transmit data empty interrupt (TXI) to be generated. The AASy flag is used to identify which slave address has been specified.

Figure 24.24 to Figure 24.26 show the AASy flag set timing in three cases.



Figure 24.24 AASy Flag Set Timing with 7-Bit Address Format Selected



Figure 24.25 AASy Flag Set Timing with 10-Bit Address Format Selected



Figure 24.26 AASy Flag Set/Clear Timing with 7-Bit/10-Bit Address Formats Mixed

# 24.7.2 Detection of the General Call Address

The RIIC has a facility for detecting the general call address  $(0000\ 000b + 0\ (write))$ . This is enabled by setting the ICSER.GCAE bit to 1.

If the address received after a start or restart condition is issued is  $0000\ 000b + 1$  (read) (start byte), the RIIC recognizes this as the address of a slave device with an "all-zero" address but not as the general call address.

When the RIIC detects the general call address, both the ICSR1.GCA flag and the ICSR2.RDRF flag are set to 1 on the rising edge of the ninth cycle of SCL clock. This leads to the generation of a receive data full interrupt (RXI). The value of the GCA flag can be confirmed to recognize that the general call address has been transmitted.

Operation after detection of the general call address is the same as normal slave receive operation.



Figure 24.27 Timing of GCA Flag Setting during Reception of General Call Address

#### 24.7.3 Device-ID Address Detection

The RIIC module has a facility for detecting device-ID addresses conformant with the  $I^2C$ -bus specification (Rev. 03). When the RIIC receives 1111 100b as the first byte after a start condition or restart condition was issued with the ICSER.DIDE bit set to 1, the RIIC recognizes the address as a device ID, sets the ICSR1.DID flag to 1 on the rising edge of the eighth SCL clock cycle when the following R/W# bit is 0, and then compares the second and subsequent bytes with its own slave address. If the address matches the value in the slave address register, the RIIC sets the corresponding ICSR1.AASy flag (y = 0 to 2) to 1.

After that, when the first byte received after a start or restart condition is issued matches the device ID address (1111 100b) again and the following R/W# bit is 1, the RIIC does not compare the second and subsequent bytes and sets the ICSR2.TDRE flag to 1.

In the device-ID address detection function, the RIIC sets the DID flag to 0 if a match with the RIIC's own slave address is not obtained or a match with the device ID address is not obtained after a match with the RIIC's own slave address and the detection of a restart condition. If the first byte after detection of a start or restart condition matches the device ID address (1111 100b) and the R/W# bit is 0, the RIIC sets the DID flag to 1 and compares the second and subsequent bytes with the RIIC's slave address. If the R/W# bit is 1, the DID flag holds the previous value and the RIIC does not compare the second and subsequent bytes. Therefore, the reception of a device-ID address can be checked by reading the DID flag after confirming that TDRE flag is 1.

Furthermore, prepare the device-ID fields (3 bytes: 12 bits indicating the manufacturer + 9 bits identifying the part + 3 bits indicating the revision) that must be sent to the host after reception of a continuous device-ID field as normal data for transmission. For details of the information that must be included in device-ID fields, contact NXP Semiconductors.



Figure 24.28 AASy/DID Flag Set/Clear Timing during Reception of Device-ID

#### 24.7.4 Host Address Detection

The RIIC has a function to detect the host address while the SMBus is operating. When the ICSER.HOAE bit is set to 1 while the ICMR3.SMBS bit is 1, the RIIC can detect the host address (0001 000b) in slave receive mode (bits MST and TRS in the ICCR2 register are 00b).

When the RIIC detects the host address, the ICSR1.HOA flag is set to 1 at the rising edge of the ninth SCL clock cycle, and at the same time, the ICSR2.RDRF flag is set to 1 when the R/W# bit is 0 (Wr bit). This causes a receive data full interrupt (RXI) to be generated. The HOA flag is used to recognize that the host address was sent from the smart battery or other devices.

If the bit following the host address (0001 000b) is an Rd bit (R/W# bit is 1), the RIIC can also detect the host address. After the host address is detected, the RIIC operates in the same manner as normal slave operation.



Figure 24.29 HOA Flag Set Timing during Reception of Host Address

# 24.8 Automatic Low-Hold Function for SCL

# 24.8.1 Function to Prevent Wrong Transmission of Transmit Data

If the shift register (ICDRS) is empty when data have not been written to the I<sup>2</sup>C-bus transmit data register (ICDRT) with the RIIC in transmission mode (ICCR2.TRS bit is 1), the SCL0 line is automatically held at the low level over the intervals shown below. This low-hold period is extended until data for transmission have been written, which prevents the unintended transmission of erroneous data.

#### Master transmit mode

- Low-level interval after a start condition or restart condition is issued
- Low-level interval between the ninth clock cycle of one transfer and the first clock cycle of the next

#### Slave transmit mode

• Low-level interval between the ninth clock cycle of one transfer and the first clock cycle of the next



Figure 24.30 Automatic Low-Hold Operation in Transmit Mode

## 24.8.2 NACK Reception Transfer Suspension Function

The RIIC has a function to suspend transfer operation when NACK is received in transmit mode (ICCR2.TRS bit is 1). This function is enabled when the ICFER.NACKE bit is set to 1 (transfer suspension enabled). If the next transmit data has already been written (ICSR2.TDRE flag is 0) when NACK is received, next data transmission at the falling edge of the ninth SCL clock cycle is automatically suspended. This prevents the SDA0 line output level from being held low when the MSB of the next transmit data is 0.

If the transfer operation is suspended by this function (ICSR2.NACKF flag is 1), transmit operation and receive operation are discontinued. To restore transmit/receive operation, be sure to set the NACKF flag to 0. In master transmit mode, after setting the NACKF flag to 0, issue a restart condition, or issue a stop condition and then issue a start condition again.



Figure 24.31 Suspension of Data Transfer When NACK is Received (NACKE = 1)

#### 24.8.3 Function to Prevent Failure to Receive Data

If response processing is delayed when receive data (ICDRR) read is delayed for a period of one transfer byte or more with receive data full (ICSR2.RDRF flag is 1) in receive mode (ICCR2.TRS bit is 0), the RIIC holds the SCL0 line low automatically immediately before the next data is received to prevent failure to receive data.

This function to prevent failure to receive data using the automatic low-hold function is also enabled even if the read processing of the final receive data is delayed and, in the meantime, the RIIC's own slave address is designated after a stop condition is issued. This function does not disturb other communication because the RIIC does not hold the SCL0 line low when a mismatch with its own slave address occurs after a stop condition is issued.

Sections in which the SCL0 line is held low can be selected with a combination of the WAIT and RDRFS bits in the ICMR3 register.

### (1) 1-Byte Receive Operation and Automatic Low-Hold Function Using the WAIT Bit

When the ICMR3.WAIT bit is set to 1, the RIIC performs 1-byte receive operation using the WAIT bit function. Furthermore, when the ICMR3.RDRFS bit is 0, the RIIC automatically sends the ICMR3.ACKBT bit value for the acknowledge bit in the period from the falling edge of the eighth SCL clock cycle to the falling edge of the ninth SCL clock cycle, and automatically holds the SCL0 line low at the falling edge of the ninth SCL clock cycle using the WAIT bit function. This low-hold is released by reading data from the ICDRR register, which enables bytewise receive operation.

The WAIT bit function is enabled for receive bytes after a match with the RIIC's own slave address (including the general call address and host address) is obtained in master receive mode or slave receive mode.

# (2) 1-Byte Receive Operation (ACK/NACK Transmission Control) and Automatic Low-Hold Function Using the RDRFS Bit

When the ICMR3.RDRFS bit is set to 1, the RIIC performs 1-byte receive operation using the RDRFS bit function. When the RDRFS bit is set to 1, the ICSR2.RDRF flag (receive data full) is set to 1 at the rising edge of the eighth SCL clock cycle, and the SCL0 line is automatically held low at the falling edge of the eighth SCL clock cycle. This low-hold is released by writing a value to the ICMR3.ACKBT bit, but cannot be released by reading data from the ICDRR register, which enables receive operation by the ACK/NACK transmission control according to the data received in byte units. The RDRFS bit function is enabled for receive bytes after a match with the RIIC's own slave address (including the general call address and host address) is obtained in master receive mode or slave receive mode.



Figure 24.32 Automatic Low-Hold Operation in Receive Mode (Using RDRFS and WAIT Bits)

#### 24.9 Arbitration-Lost Detection Functions

In addition to the normal arbitration-lost detection function defined by the I<sup>2</sup>C-bus specification, the RIIC has functions to prevent double-issue of a start condition, to detect arbitration-lost during transmission of NACK, and to detect arbitration-lost in slave transmit mode.

#### 24.9.1 Master Arbitration-Lost Detection (MALE Bit)

The RIIC drives the SDA0 line low to issue a start condition. However, if the SDA0 line has already been driven low by another master device issuing a start condition, the RIIC causes arbitration to be lost, so priority is given to transfer by the other master device. Similarly, if the ICCR2.ST bit is set to 1 while the ICCR2.BBSY flag is 1 (bus busy state), arbitration is lost, so priority is given to transfer by the other master device. No start condition is issued in this case. When a start condition is issued successfully, if the data for transmission including the address bits (i.e. the internal SDA output level) and the level on the SDA0 line do not match (the high output as the internal SDA output; i.e. the SDA0 pin is in the high-impedance state) and the low level is detected on the SDA0 line, the RIIC loses in arbitration.

After a loss in arbitration of mastership, the RIIC immediately enters slave receive mode. If a slave address (including the general call address) matches its own address at this time, the RIIC continues in slave operation.

A loss in arbitration of mastership is detected when the following conditions are met while the ICFER.MALE bit is 1 (master arbitration-lost detection enabled).

[Master arbitration-lost conditions]

- Non-matching of the internal level for output on SDA and the level on the SDA0 line after a start condition was issued by setting the ICCR2.ST bit to 1 while the ICCR2.BBSY flag was set to 0 (erroneous issuing of a start condition)
- Setting of the ICCR2.ST bit to 1 (start condition double-issue error) while the BBSY flag is set to 1
- When the transmit data excluding acknowledge (internal SDA output level) does not match the level on the SDA0 line in master transmit mode (bits MST and TRS in the ICCR2 register = 11b)



Figure 24.33 Examples of Master Arbitration-Lost Detection (MALE = 1)



Figure 24.34 Arbitration-Lost When a Start Condition is Issued (MALE = 1)

## 24.9.2 Function to Detect Loss of Arbitration during NACK Transmission (NALE Bit)

The RIIC has a function to cause arbitration to be lost if the internal SDA output level does not match the level on the SDA0 line (the high output as the internal SDA output; i.e. the SDA0 pin is in the high-impedance state) and the low level is detected on the SDA0 line during transmission of NACK in receive mode. Arbitration is lost due to a conflict of NACK transmission and ACK transmission when two or more master devices receive data from the same slave device simultaneously in a multi-master system. Such conflict occurs when multiple master devices send/receive the same information through a single slave device. Figure 24.35 shows an example of arbitration-lost detection during transmission of NACK.



Figure 24.35 Example of Arbitration-Lost Detection during Transmission of NACK (NALE = 1)

The following explains arbitration-lost detection using an example where two master devices (master A and master B) and a single slave device are connected through the bus. In this example, master A receives 2 bytes of data from the slave device, and master B receives 4 bytes of data from the slave device.

If master A and master B access the slave device simultaneously, because the slave address is identical, arbitration is not lost in both master A and master B during access to the slave device. Therefore, both master A and master B recognize that they have obtained the bus mastership and operate as such. Here, master A sends NACK when it has received 2 final bytes of data from the slave device. Meanwhile, master B sends ACK because it has not received necessary 4 bytes of data. At this time, the NACK transmission from master A and the ACK transmission from master B conflict. In general, if a conflict like this occurs, master A cannot detect ACK transmitted by master B and issues a stop condition. Therefore, the issuance of the stop condition conflicts with the SCL clock output of master B, which disturbs communication. When the RIIC receives ACK during transmission of NACK, it detects a defeat in conflict with other master devices and causes arbitration to be lost.

If arbitration is lost during transmission of NACK, the RIIC immediately cancels the slave match condition and enters slave receive mode. This prevents a stop condition from being issued, preventing a communication failure on the bus. Similarly, in the ARP command processing of SMBus, the function to detect loss of arbitration during transmission of NACK is also available for eliminating the extra clock cycle processing (such as FFh transmission processing) necessary if the UDID (Unique Device Identifier) of assign address does not match in the Get UDID (general) processing after the Assign address command.

The RIIC detects arbitration-lost during transmission of NACK when the following condition is met with the ICFER.NALE bit set to 1 (arbitration-lost detection during NACK transmission enabled).

[Condition for arbitration-lost during NACK transmission]

• When the internal SDA output level does not match the SDA0 line (ACK is received) during transmission of NACK (ICMR3.ACKBT bit = 1)

# 24.9.3 Slave Arbitration-Lost Detection (SALE Bit)

The RIIC has a function to cause arbitration to be lost if the data for transmission (i.e. the internal SDA output level) and the level on the SDA0 line do not match (the high output as the internal SDA output; i.e. the SDA0 pin is in the high-impedance state and the low level is detected on the SDA0 line in slave transmit mode). This arbitration-lost detection function is mainly used when transmitting a UDID (Unique Device Identifier) over an SMBus.

When it loses slave arbitration, the RIIC is immediately released from the slave-matched state and enters slave receive mode. This function can detect conflicts of data during transmission of UDIDs over an SMBus and eliminate subsequent redundant processing (processing for the transmission of FFh).

The RIIC detects slave arbitration-lost when the following condition is met with the ICFER.SALE bit set to 1 (slave arbitration-lost detection enabled).

#### [Condition for slave arbitration-lost]

• When transmit data excluding acknowledge (internal SDA output level) does not match the SDA0 line in slave transmit mode (bits MST and TRS in the ICCR2 register are 01b)



Figure 24.36 Example of Slave Arbitration-Lost Detection (SALE = 1)

# 24.10 Start Condition/Restart Condition/Stop Condition Issuing Function

# 24.10.1 Issuing a Start Condition

The RIIC issues a start condition when the ICCR2.ST bit is set to 1.

When the ST bit is set to 1, a start condition issuance request is made and the RIIC issues a start condition when the ICCR2.BBSY flag is 0 (bus free state). When a start condition is issued normally, the RIIC automatically shifts to the master transmit mode.

A start condition is issued in the following sequence.

#### [Start condition issuance]

- (1) Drive the SDA0 line low (high level to low level).
- (2) Ensure the time set in the ICBRH register and the start condition hold time.
- (3) Drive the SCL0 line low (high level to low level).
- (4) Detect low level of the SCL0 line and ensure the low-level period of SCL0 line set in the ICBRL register.

# 24.10.2 Issuing a Restart Condition

The RIIC issues a restart condition when the ICCR2.RS bit is set to 1.

When the RS bit is set to 1, a restart condition issuance request is made and the RIIC issues a restart condition when the ICCR2.BBSY flag is 1 (bus busy state) and the ICCR2.MST bit is 1 (master mode).

A restart condition is issued in the following sequence.

#### [Restart condition issuance]

- (1) Release the SDA0 line.
- (2) Ensure the low-level period of SCL0 line set in the ICBRL register.
- (3) Release the SCL0 line (low level to high level).
- (4) Detect a high level of the SCL0 line and ensure the time set in the ICBRL register and the restart condition setup time.
- (5) Drive the SDA0 line low (high level to low level).
- (6) Ensure the time set in the ICBRH register and the restart condition hold time.
- (7) Drive the SCL0 line low (high level to low level).
- (8) Detect a low level of the SCL0 line and ensure the low-level period of SCL0 line set in the ICBRL register.



Figure 24.37 Start Condition/Restart Condition Issue Timing (ST and RS Bits)

# 24.10.3 Issuing a Stop Condition

The RIIC issues a stop condition when the ICCR2.SP bit is set to 1.

When the SP bit is set to 1, a stop condition issuance request is made and the RIIC issues a stop condition when the ICCR2.BBSY flag is 1 (bus busy state) and the ICCR2.MST bit is 1 (master mode).

A stop condition is issued in the following sequence.

#### [Stop condition issuance]

- Drive the SDA0 line low (high level to low level).
- Ensure the low-level period of SCL0 line set in the ICBRL register.
- Release the SCL0 line (low level to high level).
- Detect a high level of the SCL0 line and ensure the time set in the ICBRH register and the stop condition setup time.
- Release the SDA0 line (low level to high level).
- Ensure the time set in the ICBRL register and the bus free time.
- Set the BBSY flag to 0 (to release the bus mastership).



Figure 24.38 Stop Condition Issue Timing (SP Bit)

### 24.11 Bus Hanging

If the clock signals from the master and slave devices go out of synchronization due to noise or other factors, the  $I^2C$ -bus might hang with a fixed level on the SCL0 line and/or SDA0 line.

As measures against the bus hanging, the RIIC has a timeout function to detect hanging by monitoring the SCL0 line, a function for the output of an extra SCL clock cycle to release the bus from a hung state due to clock signals being out of synchronization, the RIIC reset function, and internal reset function.

By checking bits SCLO, SDAO, SCLI, and SDAI in the ICCR1 register, it is possible to see whether the RIIC or its partner in communications is placing the low level on the SCL0 or SDA0 lines.

#### 24.11.1 Timeout Function

The RIIC includes a timeout function for detecting when the SCL0 line has been stuck longer than the predetermined time. The RIIC can detect an abnormal bus state by monitoring that the SCL0 line is stuck low or high for a predetermined time.

The timeout function monitors the SCL0 line state and counts the low-level period or high-level period using the internal counter. The timeout function resets the internal counter each time the SCL0 line changes (rising or falling), but continues to count unless the SCL0 line changes. If the internal counter overflows due to no SCL0 line change, the RIIC can detect the timeout and report the bus hung state.

This timeout function is enabled when the ICFER.TMOE bit is 1. It detects a hung state that the SCL0 line is stuck low or high during the following conditions:

- The bus is busy (ICCR2.BBSY flag is 1) in master mode (ICCR2.MST bit is 1).
- The RIIC's own slave address is detected (ICSR1 register is not 00h) and the bus is busy (ICCR2.BBSY flag is 1) in slave mode (ICCR2.MST bit is 0).
- The bus is free (ICCR2.BBSY flag is 0) while generation of a start condition is requested (ICCR2.ST bit is 1).

The internal counter of the timeout function works using the internal reference clock ( $IIC\phi$ ) set by the ICMR1.CKS[2:0] bits as a count source. It functions as a 16-bit counter when long mode is selected (ICMR2.TMOS bit is 0) or a 14-bit counter when short mode is selected (TMOS bit is 1).

The SCL0 line level (low/high or both levels) during which this counter is activated can be selected by the setting of bits TMOH and TMOL in the ICMR2 register. If both bits TMOL and TMOH are set to 0, the internal counter does not work.

Note: When using the timeout detection function, refer to section 24.2.4, I<sup>2</sup>C-bus Mode Register 2 (ICMR2), section 24.2.18, Timeout Internal Counter (TMOCNTL/TMOCNTU), and section 24.3.2, Initial Settings.





Figure 24.39 Timeout Function (ICMR1.CKS[2:0] bits are 000b)

### 24.11.2 Extra SCL Clock Cycle Output Function

In master mode, the RIIC module has a facility for the output of extra SCL clock cycles to release the SDA0 line of the slave device from being held at the low level due to the master being out of synchronization with the slave device. This function is mainly used in master mode to release the SDA0 line of the slave device from the state of being fixed to the low level by including extra cycles of SCL output from the RIIC with single cycles of the SCL clock as the unit if the RIIC cannot issue a stop condition because the slave device is holding the SDA0 line at the low level. Do not use this facility in normal situations. Using it when communications are proceeding correctly will lead to malfunctions. When the ICCR1.CLO bit is set to 1 in master mode, a single cycle of the SCL clock at the frequency corresponding to the transfer rate settings (settings of the ICMR1.CKS[2:0] bits, and of registers ICBRH and ICBRL) is output as an extra clock cycle. After output of this single cycle of the SCL clock, the CLO bit is automatically set to 0. Therefore, further extra clock cycles can be output consecutively by writing 1 to the CLO bit after confirming the CLO bit to be 0. When the RIIC module is in master mode and the slave device is holding the SDA0 line at the low level because synchronization with the slave device has been lost due to the effects of noise, etc., the output of a stop condition is not possible. The facility for output of an extra cycle of the SCL clock can be used to output extra cycles of SCL one by one to make the slave device release the SDA0 line from being held at the low level, thus recovering the bus from an unusable state. Release of the SDA0 line by the slave device can be monitored by reading the ICCR1.SDAI bit. After confirming release of the SDA0 line by the slave device, complete communications by reissuing the stop condition. Use this facility with the ICFER.MALE bit (master arbitration-lost detection disabled) set to 0. If the MALE bit is set to 1 (master arbitration-lost detection enabled), arbitration is lost when the value of the ICCR1.SDAO bit does not match the state of the SDA0 line, so take care on this point.

[Output conditions for using the ICCR1.CLO bit]

- When the bus is free (ICCR2.BBSY flag is 0) or in master mode (ICCR2.MST bit is 1 and ICCR2.BBSY flag is 1)
- When the communication device does not hold the SCL0 line low

Figure 24.40 shows the operation timing of the extra SCL clock cycle output function (CLO bit).



Figure 24.40 Extra SCL Clock Cycle Output Function (CLO Bit)

### 24.11.3 RIIC Reset and Internal Reset

The RIIC module incorporates a function for resetting itself. There are two types of reset. One is referred to as an RIIC reset; this initializes all registers including the ICCR2.BBSY flag. The other is referred to as an internal reset; this releases the RIIC from the slave-address matched state and initializes the internal counter while retaining other settings. After issuing a reset, be sure to set the ICCR1.IICRST bit to 0.

Both types of reset are effective for release from bus-hung states because both restore the output state of the SCL0 and SDA0 pins to the high-impedance state.

Issuing a reset during slave operation may lead to a loss of synchronization between the master device clock and the slave device clock, so avoided this where possible. Note that monitoring of the bus state, such as for the presence of a start condition, is not possible during an RIIC reset (bits ICE and IICRST in the ICCR1 register are 01b).

For a detailed description of the RIIC and internal resets, refer to section 24.14, Resets and Register and Function States When Issuing Each Condition.



### 24.12 SMBus Operation

The RIIC is available for data communication conforming to the SMBus (Version 2.0). To perform SMBus communication, set the ICMR3.SMBS bit to 1. To use the transfer rate within a range of 10 kbps to 100 kbps of the SMBus specification, set the ICMR1.CKS[2:0] bits, the ICBRH register, and the ICBRL register. In addition, determine the values of the ICMR2.DLCS bit and the ICMR2.SDDL[2:0] bits to meet the data hold time specification of 300 ns or more. If the RIIC is used only as a slave device, the transfer rate setting is not necessary, whereas the ICBRL register needs to be set to a value longer than the data setup time (250 ns).

For the SMBus device default address (1100 001b), use one of the slave address registers L0 to L2 (registers SARL0, SARL1, and SARL2), and set the corresponding SARUy.FS bit (7-bit/10-bit address format select) (y = 0 to 2) to 0 (7-bit address format).

When transmitting the UDID (Unique Device Identifier), set the ICFER.SALE bit to 1 to enable the slave arbitration-lost detection function.

#### 24.12.1 SMBus Timeout Measurement

### (1) Measuring timeout of slave device

The following period (timeout interval: T<sub>LOW:SEXT</sub>) must be measured for slave devices in SMBus communication.

• From start condition to stop condition

To measure timeout for slave devices, measure the period from start condition detection to stop condition detection with the MTU timer using a start condition detection interrupt (STI) and stop condition detection interrupt (SPI) of the RIIC. The measured timeout period must be within the total clock low-level period [slave device]  $T_{LOW:SEXT}$ : 25 ms (max.) of the SMBus specification.

If the time measured with the MTU exceeds the clock low-level detection timeout T<sub>TIMEOUT</sub>: 25 ms (min.) of the SMBus specification, the slave device must release the bus by writing 1 to the ICCR1.IICRST bit to issue an internal reset of the RIIC. When an internal reset is issued, the RIIC stops driving the bus for the SCL0 pin and SDA0 pin and make the SCL0/SDA0 pin outputs high-impedance, which releases the bus.

### (2) Measuring timeout of master device

The following periods (timeout interval: T<sub>LOW:MEXT</sub>) must be measured for master devices in SMBus communication.

- From start condition to acknowledge bit
- Between acknowledge bits
- From acknowledge bit to stop condition

To measure timeout for master devices, measure these periods with the MTU timer using a start condition detection interrupt (STI), stop condition detection interrupt (SPI), and transmit end interrupt (TEI) or receive data full interrupt (RXI) of the RIIC. The measured timeout period must be within the total clock low-level extended period (master device)  $T_{LOW:MEXT}$ : 10 ms (max.) of the SMBus specification, and the total of all  $T_{LOW:MEXT}$  from start condition to stop condition must be within  $T_{LOW:SEXT}$ : 25 ms (max.).

For the ACK receive timing (rising edge of the ninth SCL clock cycle), monitor the ICSR2.TEND flag in master transmit mode (master transmitter) and the ICSR2.RDRF flag in master receive mode (master receiver). For this reason, perform bytewise transmit operation in master transmit mode, and hold the ICMR3.RDRFS bit 0 until the byte just before reception of the final byte in master receive mode. While the RDRFS bit is 0, the RDRF flag is set to 1 at the rising edge of the ninth SCL clock cycle.

If the period measured with the MTU exceeds the total clock low-level extended period (master device)  $T_{LOW:MEXT}$ : 10 ms (max.) of the SMBus specification or the total of measured periods exceeds the clock low-level detection timeout  $T_{TIMEOUT}$ : 25 ms (min.) of the SMBus specification, the master device must stop the transaction by issuing a stop condition. In master transmit mode, immediately stop the transmit operation (writing data to the ICDRT register).





Figure 24.41 SMBus Timeout Measurement

### 24.12.2 Packet Error Code (PEC)

This MCU incorporates a CRC calculator. The CRC calculator enables transmission of a packet error code (PEC) or checking the received data of the SMBus in data communication of the RIIC. For the CRC generating polynomials of the CRC calculator, refer to section 26, CRC Calculator (CRC).

The PEC data in master transmit mode can be generated by writing all transmit data to the CRC data input register (CRCDIR) in the CRC calculator.

The PEC data in master receive mode can be checked by writing all receive data to CRCDIR in the CRC calculator and comparing the obtained value in the CRC data output register (CRCDOR) with the received PEC data.

To send ACK or NACK according to the match or mismatch result when the final byte is received as a result of the PEC code check, set the ICMR3.RDRFS bit to 1 before the rising edge of the eighth SCL clock cycle during reception of the final byte, and hold the SCL0 line low at the falling edge of the eighth clock cycle.

### 24.12.3 SMBus Host Notification Protocol (Notify ARP Master Command)

In communications over an SMBus, a slave device can temporarily act as a master device to notify the SMBus host (or ARP master) of its own slave address or to request its own slave address from the SMBus host.

For a product of this MCU to operate as an SMBus host (or ARP master), the host address (0001 000b) sent from the slave device must be detected as a slave address, so the RIIC has a function for detecting the host address. To detect the host address as a slave address, set the ICMR3.SMBS bit and the ICSER.HOAE bit to 1. Operation after the host address has been detected is the same as normal slave operation.

### 24.13 Interrupt Sources

The RIIC issues four types of interrupt request: transfer error or event generation (arbitration-lost, NACK detection, timeout detection, start condition detection, and stop condition detection), receive data full, transmit data empty, and transmit end.

Table 24.7 lists details of the several interrupt requests. The receive data full and transmit data empty are both capable of activating data transfer by the DTC.

Table 24.7 Interrupt Sources

| Symbol | Interrupt Source    | Interrupt Flag | DTC Activation | Priority | Interrupt Condition   |
|--------|---------------------|----------------|----------------|----------|-----------------------|
| EEI    | Transfer error/     | AL             | Not possible   | High     | AL = 1 • ALIE = 1     |
|        | event generation    | NACKF          |                | <b>†</b> | NACKF = 1 • NAKIE = 1 |
|        |                     | TMOF           |                |          | TMOF = 1 • TMOIE = 1  |
|        |                     | START          |                |          | START = 1 • STIE = 1  |
|        |                     | STOP           |                |          | STOP = 1 • SPIE = 1   |
| RXI∗²  | Receive data full   | RDRF           | Possible       |          | RDRF = 1 • RIE = 1    |
| TXI*1  | Transmit data empty | TDRE           | Possible       |          | TDRE = 1 • TIE = 1    |
|        |                     |                |                |          |                       |
| TEI*3  | Transmit end        | TEND           | Not possible   | Low      | TEND = 1 • TEIE = 1   |

Note: There is a delay time between the execution of a write instruction for a peripheral module by the CPU and actual writing to the module. Thus, when an interrupt flag has been cleared or an interrupt request has been masked, read the relevant flag again to check whether clearing or masking has been completed, and then return from interrupt handling. Returning from interrupt handling without checking that writing to the module has been completed creates a possibility of repeated processing of the same interrupt.

- Note 1. Because TXI is an edge-detected interrupted, it does not require clearing. Furthermore, the ICSR2.TDRE flag (a condition for TXI) is automatically set to 0 when data for transmission are written to the ICDRT register or a stop condition is detected (ICSR2.STOP flag is 1).
- Note 2. Because RXI is an edge-detected interrupted, it does not require clearing. Furthermore, the ICSR2.RDRF flag (a condition for RXI) is automatically set to 0 when data are read from the ICDRR register.
- Note 3. When using the TEI interrupt, clear the ICSR2.TEND flag in the TEI interrupt handling.

  Note that the ICSR2.TEND flag is automatically set to 0 when data for transmission are written to the ICDRT register or a stop condition is detected (ICSR2.STOP flag is 1).

Clear the each flag or mask the interrupt request during interrupt handling.

### 24.13.1 Buffer Operation for TXI and RXI Interrupts

If the conditions for generating a TXI and RXI interrupt are satisfied while the corresponding IR flag is 1, the interrupt request is not output for the ICU but retained internally (the capacity for internal retention is one request per source). An interrupt request that was being retained internally is output to the ICU when the value of the ICU.IRn.IR flag becomes 0. Internally retained interrupt requests are automatically cleared under normal conditions of usage. Internally retained interrupt requests can also be cleared by writing 0 to the corresponding interrupt enable bit in the ICIER register.



# 24.14 Resets and Register and Function States When Issuing Each Condition

The RIIC can be reset by MCU reset, RIIC reset, and internal reset functions. Table 24.8 lists the register and function states when issuing each reset or condition.

Table 24.8 Register and Function States When Issuing Each Reset or Condition

|                     |                               | MCU<br>Reset | RIIC Reset<br>(ICE = 0, IICRST = 1) | Internal Reset<br>(ICE = 1, IICRST = 1) | Start Condition/<br>Restart Condition<br>Detection | Stop Condition<br>Detection |
|---------------------|-------------------------------|--------------|-------------------------------------|-----------------------------------------|----------------------------------------------------|-----------------------------|
| ICCR1               | ICE, IICRST                   | At a reset   | Retained                            | Retained                                | Retained                                           | Retained                    |
|                     | SCLO, SDAO                    |              | At a reset                          | At a reset                              |                                                    |                             |
|                     | Others                        |              |                                     | Retained                                |                                                    |                             |
| ICCR2               | BBSY                          | At a reset   | At a reset                          | Retained                                | Retained                                           | Retained                    |
|                     | ST                            |              |                                     | At a reset                              | At a reset                                         | Retained                    |
|                     | Others                        |              |                                     |                                         |                                                    | At a reset                  |
| ICMR1               | BC[2:0]                       | At a reset   | At a reset                          | At a reset                              | At a reset                                         | Retained                    |
|                     | Others                        |              |                                     | Retained                                | Retained                                           | ]                           |
| ICMR2               |                               | At a reset   | At a reset                          | Retained                                | Retained                                           | Retained                    |
| ICMR3               |                               | At a reset   | At a reset                          | Retained                                | Retained                                           | Retained                    |
| ICFER               |                               | At a reset   | At a reset                          | Retained                                | Retained                                           | Retained                    |
| ICSER               |                               | At a reset   | At a reset                          | Retained                                | Retained                                           | Retained                    |
| ICIER               |                               | At a reset   | At a reset                          | Retained                                | Retained                                           | Retained                    |
| ICSR1               |                               | At a reset   | At a reset                          | At a reset                              | Retained                                           | At a reset                  |
| ICSR2               | TDRE, TEND                    | At a reset   | At a reset                          | At a reset                              | Retained                                           | At a reset                  |
|                     | START                         |              |                                     |                                         | Retained                                           | ]                           |
|                     | STOP                          |              |                                     |                                         | Retained                                           | Retained                    |
|                     | Others                        |              |                                     |                                         | Retained                                           | Retained                    |
|                     | SARL1, SARL2,<br>SARU1, SARU2 | At a reset   | At a reset                          | Retained                                | Retained                                           | Retained                    |
| ICBRH, I            | ICBRL                         | At a reset   | At a reset                          | Retained                                | Retained                                           | Retained                    |
| ICDRT               |                               | At a reset   | At a reset                          | Retained                                | Retained                                           | Retained                    |
| ICDRR               |                               | At a reset   | At a reset                          | Retained                                | Retained                                           | Retained                    |
| CDRS                |                               | At a reset   | At a reset                          | At a reset                              | Retained                                           | Retained                    |
| Timeout             | function                      | At a reset   | At a reset                          | Operation                               | Operation                                          | Operation                   |
| Bus free<br>measure |                               | At a reset   | At a reset                          | Operation                               | Operation                                          | Operation                   |

### 24.15 Usage Notes

### 24.15.1 Setting Module Stop Function

Module stop state can be entered or released using module stop control register B (MSTPCRB). The initial setting is for operation of the RIIC to be stopped. RIIC register access is enabled by releasing the module stop state. For details on module stop control register B, refer to section 11, Low Power Consumption.

## 24.15.2 Notes on Starting Transfer

If the IR flag corresponding to the RIIC interrupt is 1 when transfer is started (ICCR1.ICE bit is 1), follow the procedure below to clear interrupts before enabling operations. Starting transfer with the IR flag set to 1 while the ICCR1.ICE bit is 1 leads to an interrupt request being internally retained after transfer starts, and this can lead to unanticipated behavior of the IR flag.

- 1. Confirm that the ICCR1.ICE bit is 0.
- 2. Set the relevant interrupt enable bits (ICIER.TIE, etc.) on the peripheral function side to 0.
- 3. Read the relevant interrupt enable bits (ICIER.TIE, etc.) on the peripheral function side and confirm that its value is 0.
- 4. Set the IR flag to 0.

# 25. Serial Peripheral Interface (RSPI)

In this section, "PCLK" is used to refer to PCLKB.

### 25.1 Overview

This MCU includes one channel of Serial Peripheral Interface (RSPI).

The RSPI channels are capable of high-speed, full-duplex synchronous serial communications with multiple processors and peripheral devices.

Table 25.1 lists the specifications of the RSPI, and Figure 25.1 shows a block diagram of the RSPI.

In this section, m as used with the RSPI command registers (SPCMDm) indicates 0 to 7.

Table 25.1 RSPI Specifications (1/2)

| Item                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Number of channels         | One channel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| RSPI transfer functions    | <ul> <li>Use of MOSI (master out/slave in), MISO (master in/slave out), SSL (slave select), and RSPCK (RSPI clock) signals allows serial communications through SPI operation (4-wire method) or clock synchronous operation (3-wire method).</li> <li>Transmit-only operation is available.</li> <li>Communication mode: Full-duplex or transmit-only can be selected.</li> <li>Switching of the polarity of RSPCK</li> <li>Switching of the phase of RSPCK</li> </ul>                                                                                                                                                                                                                                                                                                                                                            |
| Data format                | <ul> <li>MSB first/LSB first selectable</li> <li>Transfer bit length is selectable as 8, 9, 10, 11, 12, 13, 14, 15, 16, 20, 24, or 32 bits.</li> <li>128-bit transmit/receive buffers</li> <li>Up to four frames can be transferred in one round of transmission/reception (each frame consisting of up to 32 bits).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit rate                   | <ul> <li>In master mode, the on-chip baud rate generator generates RSPCK by frequency-dividing PCLK (the division ratio ranges from divided by 2 to divided by 4096).</li> <li>In slave mode, the minimum PCLK clock divided by 8 can be input as RSPCK (the maximum frequency of RSPCK is that of PCLK divided by 8).</li> <li>Width at high level: 4 cycles of PCLK; width at low level: 4 cycles of PCLK</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                             |
| Buffer configuration       | <ul> <li>Double buffer configuration for the transmit/receive buffers</li> <li>128 bits for the transmit/receive buffers</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Error detection            | <ul> <li>Mode fault error detection</li> <li>Overrun error detection</li> <li>Parity error detection</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| SSL control function       | <ul> <li>Four SSL pins (SSLA0 to SSLA3) for each channel</li> <li>In single-master mode, SSLA0 to SSLA3 pins are output.</li> <li>In multi-master mode:     SSLA0 pin for input, and SSLA1 to SSLA3 pins for either output or unused.</li> <li>In slave mode:     SSLA0 pin for input, and SSLA1 to SSLA3 pins for unused.</li> <li>Controllable delay from SSL output assertion to RSPCK operation (RSPCK delay)     Range: 1 to 8 RSPCK cycles (set in RSPCK-cycle units)</li> <li>Controllable delay from RSPCK stop to SSL output negation (SSL negation delay)     Range: 1 to 8 RSPCK cycles (set in RSPCK-cycle units)</li> <li>Controllable wait for next-access SSL output assertion (next-access delay)     Range: 1 to 8 RSPCK cycles (set in RSPCK-cycle units)</li> <li>Function for changing SSL polarity</li> </ul> |
| Control in master transfer | <ul> <li>A transfer of up to eight commands can be executed sequentially in looped execution.</li> <li>For each command, the following can be set:     SSL signal value, bit rate, RSPCK polarity/phase, transfer data length, MSB/LSB first, burst, RSPCK delay, SSL negation delay, and next-access delay</li> <li>A transfer can be initiated by writing to the transmit buffer.</li> <li>MOSI signal value specifiable in SSL negation</li> </ul>                                                                                                                                                                                                                                                                                                                                                                              |

Table 25.1 RSPI Specifications (2/2)

| Item                           | Description                                                                                                                                                                                 |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interrupt sources              | Interrupt sources     Receive buffer full interrupt     Transmit buffer empty interrupt     RSPI error interrupt (mode fault, overrun, or parity error)     RSPI idle interrupt (RSPI idle) |
| Others                         | <ul> <li>Function for switching between CMOS output and open-drain output</li> <li>Function for initializing the RSPI</li> <li>Loopback mode</li> </ul>                                     |
| Low power consumption function | Module stop state can be set.                                                                                                                                                               |



Figure 25.1 RSPI Block Diagram

Table 25.2 lists the I/O pins used in the RSPI.

The RSPI automatically switches the I/O direction of the SSLA0 pin. SSLA0 is set as an output when the RSPI is a single master and as an input when the RSPI is a multi-master or a slave. Pins RSPCKA, MOSIA, and MISOA are automatically set as inputs or outputs according to the setting of master or slave and the level input on the SSLA0 pin. Refer to section 25.3.2, Controlling RSPI Pins for details.

Table 25.2 RSPI Pin Configuration

| Channel | Pin Name | I/O    | Function                 |
|---------|----------|--------|--------------------------|
| RSPI0   | RSPCKA   | I/O    | Clock I/O                |
|         | MOSIA    | I/O    | Master transmit data I/O |
|         | MISOA    | I/O    | Slave transmit data I/O  |
|         | SSLA0    | I/O    | Slave selection I/O      |
|         | SSLA1    | Output | Slave selection output   |
|         | SSLA2    | Output | Slave selection output   |
|         | SSLA3    | Output | Slave selection output   |

### 25.2 Register Descriptions

### 25.2.1 RSPI Control Register (SPCR)

Address(es): RSPI0.SPCR 0008 8380h



| Bit | Symbol | Bit Name                                     | Description                                                                                                                                      | R/W |
|-----|--------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | SPMS   | RSPI Mode Select                             | 0: SPI operation (4-wire method) 1: Clock synchronous operation (3-wire method)                                                                  | R/W |
| b1  | TXMD   | Communications Operating Mode Select         | Full-duplex synchronous serial communications     Serial communications consisting of only transmit operations                                   | R/W |
| b2  | MODFEN | Mode Fault Error Detection Enable            | 0: Disables the detection of mode fault error 1: Enables the detection of mode fault error                                                       |     |
| b3  | MSTR   | RSPI Master/Slave Mode Select                | 0: Slave mode<br>1: Master mode                                                                                                                  |     |
| b4  | SPEIE  | RSPI Error Interrupt Enable                  | Disables the generation of RSPI error interrupt requests     Enables the generation of RSPI error interrupt requests                             | R/W |
| b5  | SPTIE  | Transmit Buffer Empty Interrupt<br>Enable    | O: Disables the generation of transmit buffer empty interrupt requests  1: Enables the generation of transmit buffer empty interrupt requests    |     |
| b6  | SPE    | RSPI Function Enable                         | Disables the RSPI function     Enables the RSPI function                                                                                         | R/W |
| b7  | SPRIE  | RSPI Receive Buffer Full Interrupt<br>Enable | Disables the generation of RSPI receive buffer full interrupt requests     Enables the generation of RSPI receive buffer full interrupt requests | R/W |

If the SPCR.MSTR, SPCR.MODFEN, or SPCR.TXMD bit is changed while the SPCR.SPE bit is 1, subsequent operations should not be performed.

#### SPMS Bit (RSPI Mode Select)

The SPMS bit selects SPI operation (4-wire method) or clock synchronous operation (3-wire method). The SSLA0 to SSLA3 pins are not used in clock synchronous operation. The RSPCKA, MOSIA, and MISOA pins handle communications. If clock synchronous operation is to proceed in master mode (SPCR.MSTR = 1), the SPCMDm.CPHA bit can be set to either 0 or 1. Set the CPHA bit to 1 if clock synchronous operation is to proceed in slave mode (SPCR.MSTR = 0). Operation should not be performed if the CPHA bit is set to 0 when clock synchronous operation is to proceed in slave mode (SPCR.MSTR = 0).

### **TXMD Bit (Communications Operating Mode Select)**

The TXMD bit selects full-duplex synchronous serial communications or transmit operations only.

When performing communications with the TXMD bit set to 1, the RSPI performs only transmit operations and not receive operations (refer to section 25.3.6, Communications Operating Mode).

When the TXMD bit is set to 1, receive buffer full interrupt requests cannot be used.

#### **MODFEN Bit (Mode Fault Error Detection Enable)**

The MODFEN bit enables or disables the detection of mode fault error (refer to section 25.3.8, Error Detection). In addition, the RSPI determines the I/O direction of the SSLA0 to SSLA3 pins based on combinations of the MODFEN and MSTR bits (refer to section 25.3.2, Controlling RSPI Pins).

### MSTR Bit (RSPI Master/Slave Mode Select)

The MSTR bit selects master/slave mode of the RSPI. According to MSTR bit settings, the RSPI determines the direction of pins RSPCKA, MOSIA, MISOA, and SSLA0 to SSLA3.

### **SPEIE Bit (RSPI Error Interrupt Enable)**

The SPEIE bit enables or disables the generation of RSPI error interrupt requests when the RSPI detects a mode fault error and sets the SPSR.MODF flag to 1, when the RSPI detects an overrun error and sets the SPSR.OVRF flag to 1, or when the RSPI detects a parity error and sets the SPSR.PERF flag to 1 (refer to section 25.3.8, Error Detection).

#### **SPTIE Bit (Transmit Buffer Empty Interrupt Enable)**

The SPTIE bit enables or disables the generation of transmit buffer empty interrupt requests when the RSPI detects when the transmit buffer is empty.

A transmit buffer empty interrupt request when transmission starts is generated by setting the SPE and SPTIE bits to 1 at the same time or by setting the SPE bit to 1 after setting the SPTIE bit to 1.

Note that a transmit buffer interrupt is generated when the SPTIE bit is 1 even if the RSPI function is disabled (the SPTIE bit is changed to 0).

### **SPE Bit (RSPI Function Enable)**

The SPE bit enables or disables the RSPI function.

When the SPSR.MODF flag is 1, the SPE bit cannot be set to 1. For details, refer to section 25.3.8, Error Detection. Setting the SPE bit to 0 disables the RSPI function, and initializes a part of the module function. For details, refer to section 25.3.9, Initializing RSPI. Furthermore, a transmit buffer empty interrupt request is generated by the state of the SPE bit changing from 0 to 1 or from 1 to 0.

#### SPRIE Bit (RSPI Receive Buffer Full Interrupt Enable)

If the RSPI has detected a receive buffer full write after completion of a serial transfer, the SPRIE bit enables or disables the generation of an RSPI receive buffer full interrupt request.



# 25.2.2 RSPI Slave Select Polarity Register (SSLP)

Address(es): RSPI0.SSLP 0008 8381h



| Bit      | Symbol | Bit Name                     | Description                                                   | R/W |
|----------|--------|------------------------------|---------------------------------------------------------------|-----|
| b0       | SSL0P  | SSL0 Signal Polarity Setting | 0: SSL0 signal is active low 1: SSL0 signal is active high    | R/W |
| b1       | SSL1P  | SSL1 Signal Polarity Setting | 0: SSL1 signal is active low<br>1: SSL1 signal is active high | R/W |
| b2       | SSL2P  | SSL2 Signal Polarity Setting | 0: SSL2 signal is active low 1: SSL2 signal is active high    | R/W |
| b3       | SSL3P  | SSL3 Signal Polarity Setting | 0: SSL3 signal is active low<br>1: SSL3 signal is active high | R/W |
| b7 to b4 | _      | Reserved                     | These bits are read as 0. The write value should be 0.        | R/W |

If the contents of SSLP are changed while the SPCR.SPE bit is 1, subsequent operations should not be performed.

### 25.2.3 RSPI Pin Control Register (SPPCR)

Address(es): RSPI0.SPPCR 0008 8382h



| Bit    | Symbol | Bit Name                         | Description                                                                                                                                             | R/W |
|--------|--------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0     | SPLP   | RSPI Loopback                    | Normal mode     Loopback mode (data is inverted for transmission)                                                                                       | R/W |
| b1     | SPLP2  | RSPI Loopback 2                  | Normal mode     Loopback mode (data is not inverted for transmission)                                                                                   |     |
| b3, b2 | _      | Reserved                         | These bits are read as 0. The write value should be 0.                                                                                                  | R/W |
| b4     | MOIFV  | MOSI Idle Fixed Value            | O: The level output on the MOSIA pin during MOSI idling corresponds to low  1: The level output on the MOSIA pin during MOSI idling corresponds to high |     |
| b5     | MOIFE  | MOSI Idle Value Fixing<br>Enable | MOSI output value equals final data from previous transfer     MOSI output value equals the value set in the MOIFV bit                                  |     |
| b7, b6 | _      | Reserved                         | These bits are read as 0. The write value should be 0.                                                                                                  | R/W |

If the contents of SPPCR are changed while the SPCR.SPE bit is 1, subsequent operations should not be performed.

#### SPLP Bit (RSPI Loopback)

The SPLP bit selects the mode of the RSPI pins.

When the SPLP bit is set to 1, the RSPI shuts off the path between the MISOA pin and the shift register if the SPCR.MSTR bit is 1, and between the MOSIA pin and the shift register if the SPCR.MSTR bit is 0, and connects (inverts) the input path and output path for the shift register (loopback mode).

### SPLP2 Bit (RSPI Loopback 2)

The SPLP2 bit selects the mode of the RSPI pins.

When the SPLP2 bit is set to 1, the RSPI shuts off the path between the MISOA pin and the shift register if the SPCR.MSTR bit is 1, and between the MOSIA pin and the shift register if the SPCR.MSTR bit is 0, and connects the input path and output path for the shift register (loopback mode).

### **MOIFV Bit (MOSI Idle Fixed Value)**

If the MOIFE bit is 1 in master mode, the MOIFV bit determines the MOSIA pin output value during the SSL negation period (including the SSL retention period during a burst transfer).

### **MOIFE Bit (MOSI Idle Value Fixing Enable)**

The MOIFE bit fixes the MOSIA output value when the RSPI in master mode is in an SSL negation period (including the SSL retention period during a burst transfer). When the MOIFE bit is 0, the RSPI outputs the last data from the previous serial transfer during the SSL negation period to the MOSIA pin. When the MOIFE bit is 1, the RSPI outputs the fixed value set in the MOIFV bit to the MOSIA pin.



### 25.2.4 RSPI Status Register (SPSR)

Address(es): RSPI0.SPSR 0008 8383h



| Bit | Symbol | Bit Name                   | Description                                                          | R/W         |
|-----|--------|----------------------------|----------------------------------------------------------------------|-------------|
| b0  | OVRF   | Overrun Error Flag         | No overrun error occurs     An overrun error occurs                  | R/(W)<br>*1 |
| b1  | IDLNF  | RSPI Idle Flag             | 0: RSPI is in the idle state 1: RSPI is in the transfer state        | R           |
| b2  | MODF   | Mode Fault Error Flag      | No mode fault error occurs     A mode fault error occurs             | R/(W)<br>*1 |
| b3  | PERF   | Parity Error Flag          | O: No parity error occurs  1: A parity error occurs                  | R/(W)<br>*1 |
| b4  | _      | Reserved                   | This bit is read as 0. The write value should be 0.                  | R/W         |
| b5  | SPTEF  | Transmit Buffer Empty Flag | Transmit buffer has valid data     Transmit buffer has no valid data | R/(W)<br>*2 |
| b6  | _      | Reserved                   | This bit is read as 0. The write value should be 0.                  | R/W         |
| b7  | SPRF   | Receive Buffer Full Flag   | Receive buffer has no valid data     Receive buffer has valid data   | R/(W)<br>*2 |

Note 1. Only 0 can be written to clear the flag after reading 1.

Note 2. The write value should be 1.

### **OVRF Flag (Overrun Error Flag)**

The OVRF flag indicates the occurrence of an overrun error.

[Setting condition]

• When the next serial transfer ends while the SPCR.TXMD bit is 0 and the receive buffer is full.

[Clearing condition]

• When SPSR is read while the OVRF flag is 1, and then 0 is written to the OVRF flag.

### IDLNF Flag (RSPI Idle Flag)

The IDLNF flag indicates the transfer status of the RSPI.

[Setting condition]

Master mode

• Condition 1 and condition 2 are not satisfied in master mode under the [Clearing condition] below.

Slave mode

• The SPCR.SPE bit is 1 (enables the RSPI function)

[Clearing condition]

Master mode

- The following 1 is satisfied (condition 1) or all of the following 2 to 4 are satisfied (condition 2).
- 1. The SPCR.SPE bit is 0 (disables the RSPI function)
- 2. The transmit buffer (SPTX) is empty (data for the next transfer is not set)
- 3. The SPSSR.SPCP[2:0] bits are 000b (beginning of sequence control)
- 4. The RSPI internal sequencer has entered the idle state (status in which operations up to the next-access delay have finished)



#### Slave mode

• The SPCR.SPE bit is 0 (disables the RSPI function)

### **MODF Flag (Mode Fault Error Flag)**

Indicates the occurrence of a mode fault error.

[Setting condition]

Multi-master mode

• When the input level of the SSLAi pin changes to the active level while the SPCR.MSTR bit is 1 (master mode) and the SPCR.MODFEN bit is 1 (mode fault error detection is enabled), the RSPI detects a mode fault error

#### Slave mode

• When the SSLAi pin is negated before the RSPCK cycle necessary for data transfer ends while the SPCR.MSTR bit is 0 (slave mode) and the SPCR.MODFEN bit is 1 (mode fault error detection is enabled), the RSPI detects a mode fault error

The active level of the SSLAi signal is determined by the SSLP.SSLiP bit (SSLi signal polarity setting bit).

#### [Clearing condition]

• When SPSR is read while the MODF flag is 1, and then 0 is written to the MODF flag

#### **PERF Flag (Parity Error Flag)**

Indicates the occurrence of a parity error.

[Setting condition]

• When a serial transfer ends while the SPCR.TXMD bit is 0 and the SPCR2.SPPE bit is 1, the RSPI detects a parity error

#### [Clearing condition]

• When SPSR is read while the PERF flag is 1, and then 0 is written to the PERF flag

### **SPTEF Flag (Transmit Buffer Empty Flag)**

Indicates whether the transmit buffer (SPTX) in the RSPI data register has valid data.

[Setting condition]

- When the SPCR.SPE bit is 0 (disables the RSPI function)
- When data is transferred from the transmit buffer to the shift register

### [Clearing condition]

• When the number of frames of transmit data specified by the SPDCR.SPFC[1:0] bits is written to the SPDR register

The SPDR register can be set only when the SPTEF flag is 1. The data in the transmit buffer is not updated when the SPDR register is set while the SPTEF flag is 0.

#### SPRF Flag (Receive Buffer Full Flag)

Indicates whether the receive buffer (SPRX) in the RSPI data register has valid data.

[Setting condition]

• When the number of frames of receive data specified by the SPDCR.SPFC[1:0] bits is transferred from shift register to the receive buffer (SPRX) while the SPCR.TXMD bit is 0 (full duplex) and the SPRF flag is 0.

Note that the SPRF flag does not become 1 when the OVRF flag is 1.

#### [Clearing condition]

• When all of the received data are read from the SPDR register



### 25.2.5 RSPI Data Register (SPDR)





Address(es): RSPI0.SPDR.H 0008 8384h



SPDR is the interface with the buffers that hold data for transmission and reception by the RSPI.

When accessing in longwords (the SPLW bit is 1), access SPDR.

When accessing in words (the SPLW bit is 0), access the higher-order 16 bits (H) of SPDR.

The transmit buffer (SPTX) and receive buffer (SPRX) are independent but are both mapped to SPDR. Figure 25.2 shows the Configuration of SPDR.



Figure 25.2 Configuration of SPDR

The transmit and receive buffers each have four stages. The number of stages to be used is selectable by the number of frames specification bits in the RSPI data control register (SPDCR.SPFC[1:0]). The eight stages of the buffer are all mapped to the single address of SPDR.

Data written to SPDR are written to a transmit-buffer stage (SPTXn) (n = 0 to 3) and then transmitted from the buffer. The receive buffer holds received data on completion of reception. The receive buffer is not updated if an overrun is generated.

Furthermore, if the data length is other than 32 bits, bits not referred to in SPTXn (n = 0 to 3) are stored in the corresponding bits in SPRXn. For example, if the data length is 9 bits, received data are stored in the SPRXn[8:0] bits and the SPTXn[31:9] bits are stored in the SPRXn[31:9] bits.

#### (1) Bus Interface

SPDR is the interface with 32-bit wide transmit and receive buffers, each of which has four stages, for a total of 32 bytes. In other words, the 32 bytes are mapped to the 4-byte address space for SPDR. Furthermore, the unit of access for SPDR is selected by the RSPI longword access/word access specification bit in the RSPI data control register (SPDCR.SPLW). Data for transmission should be flush with the LSB end of the register. Received data are stored flush with the LSB end. Operations involved in writing to and reading from SPDR are described below.

### (a) Writing

Data written to SPDR are written to a transmit buffer (SPTXn). This is not influenced by the value of the SPDCR.SPRDTD bit unlike when reading from SPDR.

The transmit buffer includes a transmit buffer write pointer which is automatically updated to indicate the next stage each time data are written to SPDR.

Figure 25.3 shows the configuration of the bus interface with the transmit buffer in the case of writing to SPDR.



Figure 25.3 Configuration of SPDR (Writing)

The sequence for switching the transmit buffer write pointer differs with the setting of the number of frames specification bits in the RSPI data control register (SPDCR.SPFC[1:0]).

• Settings of the SPFC[1:0] bits and sequence of switching the pointer among SPTX0 to SPTX3.

```
When the SPFC[1:0] bits are 00b: SPTX0 \rightarrow SPTX0 \rightarrow SPTX0 \rightarrow ...
When the SPFC[1:0] bits are 01b: SPTX0 \rightarrow SPTX1 \rightarrow SPTX0 \rightarrow SPTX1 \rightarrow ...
```

When the SPFC[1:0] bits are 10b: SPTX0  $\rightarrow$  SPTX1  $\rightarrow$  SPTX2  $\rightarrow$  SPTX0  $\rightarrow$  SPTX1  $\rightarrow$  ...

When the SPFC[1:0] bits are 11b: SPTX0  $\rightarrow$  SPTX1  $\rightarrow$  SPTX2  $\rightarrow$  SPTX3  $\rightarrow$  SPTX0  $\rightarrow$  SPTX1  $\rightarrow$  ...

When 1 is written to the RSPI function enable bit in the RSPI control register (SPCR.SPE) while the bit's current value is 0, SPTX0 will be the destination the next time writing proceeds.

When writing to the transmit buffer (SPTXn) after generation of the transmit buffer empty interrupt (after the SPSR.SPTEF flag becomes 1), write the number of frames set by the number of frames specification bits (SPFC[1:0]) in the RSPI data control register (SPDCR). Even if the number of frames is written to the transmit buffer (SPTXn), the value of the buffer is not updated after completion of the writing and before generation of the next transmit buffer empty interrupt (while the SPSR.SPTEF flag is 0).

### (b) Reading

SPDR can be read to read the value of a receive buffer (SPRXn) or a transmit buffer (SPTXn). The setting of the RSPI receive/transmit data select bit in the RSPI data control register (SPDCR.SPRDTD) selects whether reading is of the receive or transmit buffer.

The sequence of reading the SPDR register is controlled by independent pointers, receive buffer read pointer and transmit buffer read pointer.

Figure 25.4 shows the configuration of the bus interface with the receive and transmit buffers in the case of reading from SPDR.



Figure 25.4 Configuration of SPDR (Reading)

Reading the receive buffer switches the receive buffer read pointer to the next buffer automatically.

The sequence of switching the receive buffer read pointer is the same as that for the transmit buffer write pointer. However, when 1 is written to the RSPI function enable bit in the RSPI control register (SPCR.SPE) while the bit's current value is 0, SPRX0 will be indicated by the buffer read pointer the next time reading proceeds.

The transmit buffer read pointer is updated when writing to SPDR, and not updated when reading from the transmit buffer. When reading from the transmit buffer, the value most recently written to SPDR is read. However, after generation of the transmit buffer empty interrupt, the values read from the transmit buffer are all 0 in the interval after completion of writing the number of frames of data specified in the number of frames specification bits (SPDCR.SPFC[1:0]) and before generation of the next buffer empty interrupt (while the SPSR.SPTEF flag is 0).

## 25.2.6 RSPI Sequence Control Register (SPSCR)

Address(es): RSPI0.SPSCR 0008 8388h



| Bit      | Symbol     | Bit Name                              | Description                                                   | R/W |
|----------|------------|---------------------------------------|---------------------------------------------------------------|-----|
| b2 to b0 | SPSLN[2:0] | RSPI Sequence Length<br>Specification | b2 b0 Sequence Length $0.00000000000000000000000000000000000$ | R/W |
| b7 to b3 | _          | Reserved                              | These bits are read as 0. The write value should be 0.        | R/W |

SPSCR sets the sequence length when the RSPI operates in master mode. When changing the SPSCR.SPSLN[2:0] bits while both the SPCR.MSTR and SPCR.SPE bits are 1, the bits should be changed while the SPSR.IDLNF flag is 0.

### SPSLN[2:0] Bits (RSPI Sequence Length Specification)

The SPSLN[2:0] bits specify a sequence length when the RSPI in master mode performs sequential operations. The RSPI in master mode changes SPCMD0 to SPCMD7 registers to be referenced and the order in which they are referenced according to the sequence length that is set in the SPSLN[2:0] bits.

In slave mode, SPCMD0 is referred.

## 25.2.7 RSPI Sequence Status Register (SPSSR)

Address(es): RSPI0.SPSSR 0008 8389h



| Bit      | Symbol     | Bit Name                        | Description                                                                                                                                   | R/W |
|----------|------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b2 to b0 | SPCP[2:0]  | RSPI Command Pointer            | b2 b0<br>0 0 0: SPCMD0<br>0 0 1: SPCMD1<br>0 1 0: SPCMD2<br>0 1 1: SPCMD3<br>1 0 0: SPCMD4<br>1 0 1: SPCMD5<br>1 1 0: SPCMD6<br>1 1 1: SPCMD7 | R   |
| b3       | _          | Reserved                        | This bit is read as 0.                                                                                                                        | R   |
| b6 to b4 | SPECM[2:0] | CM[2:0] RSPI Error Command    0 |                                                                                                                                               | R   |
| b7       | _          | Reserved                        | This bit is read as 0.                                                                                                                        | R   |

SPSSR indicates the sequence control status when the RSPI operates in master mode. Any writing to SPSSR is ignored.

### SPCP[2:0] Bits (RSPI Command Pointer)

The SPCP[2:0] bits indicate SPCMDm that is currently pointed to by the pointer during sequence control by the RSPI. For the RSPI's sequence control, refer to section 25.3.10.1, Master Mode Operation.

### SPECM[2:0] Bits (RSPI Error Command)

The SPECM[2:0] bits indicate SPCMDm that is specified by the SPCP[2:0] bits when an error is detected during sequence control by the RSPI. The RSPI updates the SPECM[2:0] bits only when an error is detected. If both the SPSR.OVRF and SPSR.MODF flags are 0 and there is no error, the values of the SPECM[2:0] bits have no meaning. For the RSPI's error detection function, refer to section 25.3.8, Error Detection. For the RSPI's sequence control, refer to section 25.3.10.1, Master Mode Operation.

### 25.2.8 RSPI Bit Rate Register (SPBR)

Address(es): RSPI0.SPBR 0008 838Ah



SPBR sets the bit rate in master mode. If the contents of SPBR are changed while both the SPCR.MSTR and SPCR.SPE bits are 1, subsequent operations should not be performed.

When the RSPI is used in slave mode, the bit rate depends on the bit rate of the input clock (bit rate satisfying the electrical characteristics should be used) regardless of the settings of SPBR and the SPCMDm.BRDV[1:0] bits (bit rate division setting bits).

The bit rate is determined by combinations of the SPBR setting and the SPCMDm.BRDV[1:0] bit setting. The equation for calculating the bit rate is given below. In the equation, n denotes an SPBR setting (0, 1, 2, ..., 255), and N denotes a BRDV[1:0] bit setting (0, 1, 2, 3).

Bit rate = 
$$\frac{f(PCLK)}{2 \times (n+1) \times 2^{N}}$$

Table 25.3 lists examples of the relationship among the SPBR settings, the BRDV[1:0] settings, and bit rates. Use the bit rate that meets electrical characteristics based on the AC specifications of the target device.

Table 25.3 Relationship among SPBR Settings, BRDV[1:0] Settings, and Bit Rates

|          |                    | Division | Bit Rate      |
|----------|--------------------|----------|---------------|
| SPBR (n) | BRDV[1:0] Bits (N) | Ratio    | PCLK = 32 MHz |
| 0        | 0                  | 2        | 16.0 Mbps     |
| 1        | 0                  | 4        | 8.00 Mbps     |
| 2        | 0                  | 6        | 5.33 Mbps     |
| 3        | 0                  | 8        | 4.00 Mbps     |
| 4        | 0                  | 10       | 3.20 Mbps     |
| 5        | 0                  | 12       | 2.67 Mbps     |
| 5        | 1                  | 24       | 1.33 Mbps     |
| 5        | 2                  | 48       | 667 kbps      |
| 5        | 3                  | 96       | 333 kbps      |
| 255      | 3                  | 4096     | 7.81 kbps     |

### 25.2.9 RSPI Data Control Register (SPDCR)

Address(es): RSPI0.SPDCR 0008 838Bh



| Bit    | Symbol    | Bit Name                                           | Description                                                                                                                                   | R/W |
|--------|-----------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1, b0 | SPFC[1:0] | Number of Frames<br>Specification                  | b1 b0<br>0 0: 1 frame<br>0 1: 2 frames<br>1 0: 3 frames<br>1 1: 4 frames                                                                      | R/W |
| b3, b2 | _         | Reserved                                           | These bits are read as 0. The write value should be 0.                                                                                        | R/W |
| b4     | SPRDTD    | RSPI Receive/Transmit<br>Data Select               | SPDR values are read from the receive buffer     SPDR values are read from the transmit buffer     (but only if the transmit buffer is empty) | R/W |
| b5     | SPLW      | RSPI Longword Access/<br>Word Access Specification | 0: SPDR is accessed in words 1: SPDR is accessed in longwords                                                                                 | R/W |
| b7, b6 | _         | Reserved                                           | These bits are read as 0. The write value should be 0.                                                                                        |     |

Up to four frames can be transmitted or received in one round of transmission or reception activation. The amount of data in each transfer is controlled by the combination of the SPCMDm.SPB[3:0] bits, the SPSCR.SPSLN[2:0] bits, and the SPDCR.SPFC[1:0] bits.

When changing the SPDCR.SPFC[1:0] bits while the SPCR.SPE bit is 1, the bits should be changed while the SPSR.IDLNF flag is 0.

### SPFC[1:0] Bits (Number of Frames Specification)

The SPFC[1:0] bits specify the number of frames that can be stored in SPDR (per transfer activation). Up to four frames can be transmitted or received in one round of transmission or reception, and the amount of data is determined by the combination of the SPSCR.SPSLN[2:0] bits, and the SPDCR.SPFC[1:0] bits. Furthermore, the setting of the SPFC[1:0] bits adjusts the number of frames for generation of RSPI receive buffer full interrupt, and start of transmission or generation of transmit buffer empty interrupts.

When the number of frames of transmit data specified by SPFC[1:0] bits is written to the SPDR register, the SPSR.SPTEF flag becomes 0 and transmission starts. Then, when the specified number of frames of transmit data has been transferred to the shift register, the SPTEF flag becomes 1 and the RSPI transmit buffer empty interrupt is generated.

When the number of frames specified by the SPFC[1:0] bits are received, the SPSR.SPRF flag becomes 1 and the RSPI receive buffer full interrupt is generated.

Table 25.4 lists the frame configurations that can be stored in SPDR and examples of combinations of settings for transmission and reception. If combinations of settings other than those shown in the examples are made, subsequent operations should not be performed.

Table 25.4 Settable Combinations of SPSLN[2:0] Bits and SPFC[1:0] Bits

| Setting | SPSLN[2:0] | SPFC[1:0] | Number of Frames in a Single Sequence | Number of Frames at which Transmit Buffer or Receive Buffer Status Becomes "Has Valid Data" |
|---------|------------|-----------|---------------------------------------|---------------------------------------------------------------------------------------------|
| 1-1     | 000b       | 00b       | 1                                     | 1                                                                                           |
| 1-2     | 000b       | 01b       | 2                                     | 2                                                                                           |
| 1-3     | 000b       | 10b       | 3                                     | 3                                                                                           |
| 1-4     | 000b       | 11b       | 4                                     | 4                                                                                           |
| 2-1     | 001b       | 01b       | 2                                     | 2                                                                                           |
| 2-2     | 001b       | 11b       | 4                                     | 4                                                                                           |
| 3       | 010b       | 10b       | 3                                     | 3                                                                                           |
| 4       | 011b       | 11b       | 4                                     | 4                                                                                           |
| 5       | 100b       | 00b       | 5                                     | 1                                                                                           |
| 6       | 101b       | 00b       | 6                                     | 1                                                                                           |
| 7       | 110b       | 00b       | 7                                     | 1                                                                                           |
| 8       | 111b       | 00b       | 8                                     | 1                                                                                           |

### SPRDTD Bit (RSPI Receive/Transmit Data Select)

The SPRDTD bit selects whether the SPDR reads values from the receive buffer or from the transmit buffer.

If reading is from the transmit buffer, the value written to SPDR register immediately beforehand is read.

When reading the transmit buffer, do so before writing of the number of frames set in the SPFC[1:0] bits is finished and after generation of the transmit buffer empty interrupt (While the SPSR.SPTEF flag is 1).

For details, refer to section 25.2.5, RSPI Data Register (SPDR).

### SPLW Bit (RSPI Longword Access/Word Access Specification)

The SPLW bit specifies the access width for SPDR. Access to SPDR is in words when the SPLW bit is 0 and in longwords when the SPLW bit is 1.

Also, when the SPLW bit is 0, set the SPCMDm.SPB[3:0] bits (RSPI data length setting bits) to 8 to 16 bits. When 20, 24, or 32 bits is specified, operations should not be performed.

## 25.2.10 RSPI Clock Delay Register (SPCKD)

Address(es): RSPI0.SPCKD 0008 838Ch



| Bit      | Symbol     | Bit Name            | Description                                                                                                                  | R/W |
|----------|------------|---------------------|------------------------------------------------------------------------------------------------------------------------------|-----|
| b2 to b0 | SCKDL[2:0] | RSPCK Delay Setting | b2 b0<br>0 0 0:1 RSPCK<br>0 0 1:2 RSPCK<br>0 1 0:3 RSPCK<br>0 1 1:4 RSPCK<br>1 0 0:5 RSPCK<br>1 0 1:6 RSPCK<br>1 1 0:7 RSPCK | R/W |
| b7 to b3 |            | Reserved            | 1 1 1: 8 RSPCK  These bits are read as 0. The write value should be 0.                                                       | R/W |

SPCKD sets a period from the beginning of SSLAi signal assertion to RSPCK oscillation (RSPCK delay) when the SPCMDm.SCKDEN bit is 1. If the contents of SPCKD are changed while both the SPCR.MSTR and SPCR.SPE bits are 1, subsequent operations should not be performed.

### SCKDL[2:0] Bits (RSPCK Delay Setting)

The SCKDL[2:0] bits set an RSPCK delay value when the SPCMDm.SCKDEN bit is 1. When using the RSPI in slave mode, set the SCKDL[2:0] bits to 000b.

## 25.2.11 RSPI Slave Select Negation Delay Register (SSLND)

Address(es): RSPI0.SSLND 0008 838Dh



| Bit      | Symbol     | Bit Name                   | Description                                                                                                                                   | R/W |
|----------|------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b2 to b0 | SLNDL[2:0] | SSL Negation Delay Setting | b2 b0<br>0 0 0:1 RSPCK<br>0 0 1:2 RSPCK<br>0 1 0:3 RSPCK<br>0 1 1:4 RSPCK<br>1 0 0:5 RSPCK<br>1 0 1:6 RSPCK<br>1 1 0:7 RSPCK<br>1 1 1:8 RSPCK | R/W |
| b7 to b3 | _          | Reserved                   | These bits are read as 0. The write value should be 0.                                                                                        | R/W |

SSLND sets a period (SSL negation delay) from the transmission of a final RSPCK edge to the negation of the SSLAi signal during a serial transfer by the RSPI in master mode. If the contents of SSLND are changed while both the SPCR.MSTR and SPCR.SPE bits are 1, subsequent operations should not be performed.

### SLNDL[2:0] Bits (SSL Negation Delay Setting)

The SLNDL[2:0] bits set an SSL negation delay value when the RSPI is in master mode. When using the RSPI in slave mode, set the SLNDL[2:0] bits to 000b.

## 25.2.12 RSPI Next-Access Delay Register (SPND)

Address(es): RSPI0.SPND 0008 838Eh



| Bit      | Symbol     | Bit Name                       | Description                                            | R/W |
|----------|------------|--------------------------------|--------------------------------------------------------|-----|
| b2 to b0 | SPNDL[2:0] | RSPI Next-Access Delay Setting | b2 b0<br>0 0 0: 1 RSPCK + 2 PCLK                       | R/W |
|          |            |                                | 0 0 1: 2 RSPCK + 2 PCLK                                |     |
|          |            |                                | 0 1 0: 3 RSPCK + 2 PCLK                                |     |
|          |            |                                | 0 1 1: 4 RSPCK + 2 PCLK                                |     |
|          |            |                                | 1 0 0: 5 RSPCK + 2 PCLK                                |     |
|          |            |                                | 1 0 1: 6 RSPCK + 2 PCLK                                |     |
|          |            |                                | 1 1 0: 7 RSPCK + 2 PCLK                                |     |
|          |            |                                | 1 1 1:8 RSPCK + 2 PCLK                                 |     |
| b7 to b3 | _          | Reserved                       | These bits are read as 0. The write value should be 0. | R/W |

SPND sets a non-active period (next-access delay) of the SSLAi signal after termination of a serial transfer when the SPCMDm.SPNDEN bit is 1. If the contents of SPND are changed while both the SPCR.MSTR and SPCR.SPE bits are 1, subsequent operations should not be performed.

### SPNDL[2:0] Bits (RSPI Next-Access Delay Setting)

The SPNDL[2:0] bits set a next-access delay when the SPCMDm.SPNDEN bit is 1. When using the RSPI in slave mode, set the SPNDL[2:0] bits to 000b.

### 25.2.13 RSPI Control Register 2 (SPCR2)

Address(es): RSPI0.SPCR2 0008 838Fh



| Bit      | Symbol | Bit Name                   | Description                                                                                                                                                                                                                                                                                                                                                | R/W |  |  |  |
|----------|--------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|
| b0       | SPPE   | PE Parity Enable           | <ul> <li>0: Does not add the parity bit to transmit data and does not check the parity bit of receive data</li> <li>1: Adds the parity bit to transmit data and checks the parity bit of receive data (when SPCR.TXMD = 0)</li> <li>Adds the parity bit to transmit data but does not check the parity bit of receive data (when SPCR.TXMD = 1)</li> </ul> |     |  |  |  |
| b1       | SPOE   | Parity Mode                | Selects even parity for use in transmission and reception     Selects odd parity for use in transmission and reception                                                                                                                                                                                                                                     |     |  |  |  |
| b2       | SPIIE  | RSPI Idle Interrupt Enable | e 0: Disables the generation of idle interrupt requests 1: Enables the generation of idle interrupt requests                                                                                                                                                                                                                                               |     |  |  |  |
| b3       | PTE    | Parity Self-Diagnosis      | Disables the self-diagnosis function of the parity circuit     Enables the self-diagnosis function of the parity circuit                                                                                                                                                                                                                                   | R/W |  |  |  |
| b7 to b4 | _      | Reserved                   | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                                                                                                                     | R/W |  |  |  |

If the SPPE or SPOE bit in SPCR2 is changed while the SPCR.SPE bit is 1, subsequent operations should not be performed.

#### **SPPE Bit (Parity Enable)**

The SPPE bit enables or disables the parity function.

The parity bit is added to transmit data and parity checking is performed for receive data when the SPCR.TXMD bit is 0 and the SPCR2.SPPE bit is 1.

The parity bit is added to transmit data but parity checking is not performed for receive data when the SPCR.TXMD bit is 1 and the SPCR2.SPPE bit is 1.

### **SPOE Bit (Parity Mode)**

The SPOE bit specifies odd or even parity.

When even parity is set, parity bit addition is performed so that the total number of 1-bits in the transmit/receive character plus the parity bit is even. Similarly, when odd parity is set, parity bit addition is performed so that the total number of 1-bits in the transmit/receive character plus the parity bit is odd.

The SPOE bit is valid only when the SPPE bit is 1.

### SPIIE Bit (RSPI Idle Interrupt Enable)

The SPIIE bit enables or disables the generation of RSPI idle interrupt requests when the RSPI being in the idle state is detected and the SPSR.IDLNF flag is set to 0.

### PTE Bit (Parity Self-Diagnosis)

The PTE bit enables the self-diagnosis function of the parity circuit in order to check whether the parity function is operating correctly.



# 25.2.14 RSPI Command Registers 0 to 7 (SPCMD0 to SPCMD7)

Address(es): RSPI0.SPCMD0 0008 8390h, RSPI0.SPCMD1 0008 8392h, RSPI0.SPCMD2 0008 8394h, RSPI0.SPCMD3 0008 8396h, RSPI0.SPCMD4 0008 8398h, RSPI0.SPCMD5 0008 839Ah, RSPI0.SPCMD6 0008 839Ch, RSPI0.SPCMD7 0008 839Eh



| Bit       | it Symbol Bit Name |                                      | Description                                                                                                                                                                                                                                                    | R/W |
|-----------|--------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0        | СРНА               | RSPCK Phase Setting                  | Data sampling on odd edge, data variation on even edge     Data variation on odd edge, data sampling on even edge                                                                                                                                              | R/W |
| b1        | CPOL               | RSPCK Polarity Setting               | 0: RSPCK is low when idle 1: RSPCK is high when idle                                                                                                                                                                                                           | R/W |
| b3, b2    | BRDV[1:0]          | Bit Rate Division Setting            | b3 b2 0 0: These bits select the base bit rate 0 1: These bits select the base bit rate divided by 2 1 0: These bits select the base bit rate divided by 4 1 1: These bits select the base bit rate divided by 8                                               | R/W |
| b6 to b4  | SSLA[2:0]          | SSL Signal Assertion Setting         | b6 b4 0 0 0: SSL0 0 1: SSL1 0 1 0: SSL2 0 1 1: SSL3 1 x x: Setting prohibited x: Don't care                                                                                                                                                                    | R/W |
| b7        | SSLKP              | SSL Signal Level Keeping             | Negates all SSL signals upon completion of transfer     Reeps the SSL signal level from the end of transfer until the beginning of the next access                                                                                                             | R/W |
| b11 to b8 | SPB[3:0]           | RSPI Data Length Setting             | b11 b8 0100 to 0111: 8 bits 1 0 0 0:9 bits 1 0 0 1:10 bits 1 0 1 0:11 bits 1 0 1 1:12 bits 1 0 1 1:12 bits 1 1 0 0:13 bits 1 1 0 0:13 bits 1 1 0 0:15 bits 1 1 1 0:15 bits 1 1 1 1:16 bits 1 1 1 1:16 bits 0 0 0 0:20 bits 0 0 0 1:24 bits 0010, 0011: 32 bits | R/W |
| b12       | LSBF               | RSPI LSB First                       | 0: MSB first<br>1: LSB first                                                                                                                                                                                                                                   | R/W |
| b13       | SPNDEN             | RSPI Next-Access Delay<br>Enable     | 0: A next-access delay of 1 RSPCK + 2 PCLK 1: A next-access delay is equal to the setting of the RSPI next-access delay register (SPND)                                                                                                                        | R/W |
| b14       | SLNDEN             | SSL Negation Delay Setting<br>Enable | O: An SSL negation delay of 1 RSPCK     1: An SSL negation delay is equal to the setting of the RSPI slave select negation delay register (SSLND)                                                                                                              | R/W |
| b15       | SCKDEN             | RSPCK Delay Setting Enable           | 0: An RSPCK delay of 1 RSPCK 1: An RSPCK delay is equal to the setting of the RSPI clock delay register (SPCKD)                                                                                                                                                | R/W |

SPCMDm register is used to set a transfer format for the RSPI in master mode. Each channel has eight RSPI command registers (SPCMD0 to SPCMD7). Some of the bits in SPCMD0 register is used to set a transfer mode for the RSPI in slave mode. The RSPI in master mode sequentially references SPCMDm register according to the settings in the SPSCR.SPSLN[2:0] bits, and executes the serial transfer that is set in the referenced SPCMDm register.

SPCMDm register should be set while the transmit buffer is empty (data for the next transfer is not set) and before setting of the data that is to be transmitted when that SPCMDm register is referenced.

SPCMDm that is referenced by the RSPI in master mode can be checked by means of the SPSSR.SPCP[2:0] bits. If the contents of SPCMDm are changed while the SPCR.MSTR bit is 0 and the SPCR.SPE bit is 1, subsequent operations should not be performed.

### CPHA Bit (RSPCK Phase Setting)

The CPHA bit sets an RSPCK phase of the RSPI in master mode or slave mode. Data communications between RSPI modules require the same RSPCK phase setting between the modules.

#### **CPOL Bit (RSPCK Polarity Setting)**

The CPOL bit sets an RSPCK polarity of the RSPI in master mode or slave mode. Data communications between RSPI modules require the same RSPCK polarity setting between the modules.

### BRDV[1:0] Bits (Bit Rate Division Setting)

The BRDV[1:0] bits are used to determine the bit rate. A bit rate is determined by combinations of the settings in the BRDV[1:0] bits and SPBR (refer to section 25.2.8, RSPI Bit Rate Register (SPBR)). The settings in SPBR determine the base bit rate. The settings in the BRDV[1:0] bits are used to select a bit rate which is obtained by dividing the base bit rate by 1, 2, 4, or 8. In SPCMDm register, different BRDV[1:0] bit settings can be specified. This enables execution of serial transfers at a different bit rate for each command.

#### SSLA[2:0] Bits (SSL Signal Assertion Setting)

The SSLA[2:0] bits control the SSLAi signal assertion when the RSPI performs serial transfers in master mode. Setting the SSLA[2:0] bits controls the assertion for the SSLAi signal. When an SSLAi signal is asserted, its polarity is determined by the set value in the corresponding SSLP. When the SSLA[2:0] bits are set to 000b in multi-master mode, serial transfers are performed with all the SSL signals in the negated state (as the SSLA0 pin acts as input). When using the RSPI in slave mode, set the SSLA[2:0] bits to 000b.

### SSLKP Bit (SSL Signal Level Keeping)

When the RSPI in master mode performs a serial transfer, the SSLKP bit specifies whether the SSLAi signal level for the current command is to be kept or negated between the SSL negation timing associated with the current command and the SSL assertion timing associated with the next command.

Setting the SSLKP bit to 1 enables a burst transfer. For details, refer to section 25.3.10.1, Master Mode Operation (4) Burst Transfer.

When using the RSPI in slave mode, the SSLKP bit should be set to 0.

### SPB[3:0] Bits (RSPI Data Length Setting)

The SPB[3:0] bits set a transfer data length for the RSPI in master mode or slave mode. When the SPLW bit is 0, set the SPB[3:0] bits to "0100b" (8 bits) to "1111b" (16 bits).

#### LSBF Bit (RSPI LSB First)

The LSBF bit sets the data format of the RSPI in master mode or slave mode to MSB first or LSB first.



### SPNDEN Bit (RSPI Next-Access Delay Enable)

The SPNDEN bit sets the period from the time the RSPI in master mode terminates a serial transfer and sets the SSLAi signal inactive until the RSPI enables the SSLAi signal assertion for the next access (next-access delay). If the SPNDEN bit is 0, the RSPI sets the next-access delay to 1 RSPCK + 2 PCLK. If the SPNDEN bit is 1, the RSPI inserts a next-access delay in compliance with the SPND setting.

When using the RSPI in slave mode, the SPNDEN bit should be set to 0.

#### **SLNDEN Bit (SSL Negation Delay Setting Enable)**

The SLNDEN bit sets the period from the time the RSPI in master mode stops RSPCK oscillation until the RSPI sets the SSLAi signal inactive (SSL negation delay). If the SLNDEN bit is 0, the RSPI sets the SSL negation delay to 1 RSPCK. If the SLNDEN bit is 1, the RSPI negates the SSL signal at an SSL negation delay in compliance with the SSLND setting.

When using the RSPI in slave mode, the SLNDEN bit should be set to 0.

#### **SCKDEN Bit (RSPCK Delay Setting Enable)**

The SCKDEN bit sets the period from the point when the RSPI in master mode activates the SSLAi signal until the RSPCK starts oscillation (RSPI clock delay). If the SCKDEN bit is 0, the RSPI sets the RSPCK delay to 1 RSPCK. If the SCKDEN bit is 1, the RSPI starts the oscillation of RSPCK at an RSPCK delay in compliance with the SPCKD setting. When using the RSPI in slave mode, the SCKDEN bit should be set to 0.

#### 25.3 Operation

In this section, the serial transfer period means a period from the beginning of driving valid data to the fetching of the final valid data.

#### 25.3.1 Overview of RSPI Operations

The RSPI is capable of synchronous serial transfers in slave mode (SPI operation), single-master mode (SPI operation), multi-master mode (SPI operation), slave mode (clock synchronous operation), and master mode (clock synchronous operation). A particular mode of the RSPI can be selected by using the MSTR, MODFEN, and SPMS bits in SPCR. Table 25.5 lists the relationship between RSPI modes and SPCR settings, and a description of each mode.

**Table 25.5** Relationship between RSPI Modes and SPCR Settings and Description of Each Mode

| Mode                            | Slave<br>(SPI Operation)                    | Single-Master<br>(SPI Operation)                                                                                     | Multi-Master<br>(SPI Operation)                                                                                      | Slave<br>(Clock Synchronous<br>Operation) | Master<br>(Clock Synchronous<br>Operation)                                                                           |
|---------------------------------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------|
| MSTR bit setting                | 0                                           | 1                                                                                                                    | 1                                                                                                                    | 0                                         | 1                                                                                                                    |
| MODFEN bit setting              | 0 or 1                                      | 0                                                                                                                    | 1                                                                                                                    | 0                                         | 0                                                                                                                    |
| SPMS bit setting                | 0                                           | 0                                                                                                                    | 0                                                                                                                    | 1                                         | 1                                                                                                                    |
| RSPCKA signal                   | Input                                       | Output                                                                                                               | Output/Hi-Z                                                                                                          | Input                                     | Output                                                                                                               |
| MOSIA signal                    | Input                                       | Output                                                                                                               | Output/Hi-Z                                                                                                          | Input                                     | Output                                                                                                               |
| MISOA signal                    | Output/Hi-Z                                 | Input                                                                                                                | Input                                                                                                                | Output                                    | Input                                                                                                                |
| SSLA0 signal                    | Input                                       | Output                                                                                                               | Input                                                                                                                | Hi-Z*1                                    | Hi-Z*1                                                                                                               |
| SSLA1 to SSLA3 signals          | Hi-Z*1                                      | Output                                                                                                               | Output/Hi-Z                                                                                                          | Hi-Z*1                                    | Hi-Z*1                                                                                                               |
| SSL polarity change function    | Supported                                   | Supported                                                                                                            | Supported                                                                                                            | _                                         | _                                                                                                                    |
| Transfer rate                   | Up to PCLK/8                                | Up to PCLK/2                                                                                                         | Up to PCLK/2                                                                                                         | Up to PCLK/8                              | Up to PCLK/2                                                                                                         |
| Clock source                    | RSPCK input                                 | On-chip baud rate generator                                                                                          | On-chip baud rate generator                                                                                          | RSPCK input                               | On-chip baud rate generator                                                                                          |
| Clock polarity                  |                                             | •                                                                                                                    | Two                                                                                                                  |                                           | •                                                                                                                    |
| Clock phase                     | Two                                         | Two                                                                                                                  | Two                                                                                                                  | One (CPHA = 1)                            | Two                                                                                                                  |
| First transfer bit              |                                             | •                                                                                                                    | MSB/LSB                                                                                                              | 1                                         | •                                                                                                                    |
| Transfer data length            |                                             |                                                                                                                      | 8 to 16, 20, 24, 32 bit                                                                                              | S                                         |                                                                                                                      |
| Burst transfer                  | Possible<br>(CPHA = 1)                      | Possible<br>(CPHA = 0,1)                                                                                             | Possible<br>(CPHA = 0,1)                                                                                             | _                                         | _                                                                                                                    |
| RSPCK delay control             | Not supported                               | Supported                                                                                                            | Supported                                                                                                            | Not supported                             | Supported                                                                                                            |
| SSL negation delay control      | Not supported                               | Supported                                                                                                            | Supported                                                                                                            | Not supported                             | Supported                                                                                                            |
| Next-access delay control       | Not supported                               | Supported                                                                                                            | Supported                                                                                                            | Not supported                             | Supported                                                                                                            |
| Transfer activation method      | SSL input active<br>or RSPCK<br>oscillation | Transmit buffer is written to at generation of a transmit buffer empty interrupt request or when the SPTEF flag is 1 | Transmit buffer is written to at generation of a transmit buffer empty interrupt request or when the SPTEF flag is 1 | RSPCK oscillation                         | Transmit buffer is written to at generation of a transmit buffer empty interrupt request or when the SPTEF flag is 1 |
| Sequence control                | Not supported                               | Supported                                                                                                            | Supported                                                                                                            | Not supported                             | Supported                                                                                                            |
| Transmit buffer empty detection |                                             |                                                                                                                      | Supported                                                                                                            |                                           |                                                                                                                      |
| Receive buffer full detection   |                                             |                                                                                                                      | Supported*2                                                                                                          |                                           |                                                                                                                      |
| Overrun error detection         |                                             |                                                                                                                      | Supported*2                                                                                                          |                                           |                                                                                                                      |
| Parity error detection          |                                             |                                                                                                                      | Supported*2,*3                                                                                                       |                                           |                                                                                                                      |
| Mode fault error detection      | Supported<br>(MODFEN = 1)                   | Not supported                                                                                                        | Supported                                                                                                            | Not supported                             | Not supported                                                                                                        |

Note 1.

This function is not supported in this mode.

When the SPCR.TXMD bit is 1, receiver buffer full detection, overrun error detection, and parity error detection are not performed. Note 2.

Note 3. When the SPCR2.SPPE bit is 0, parity error detection is not performed.

### 25.3.2 Controlling RSPI Pins

According to the MSTR, MODFEN, and SPMS bits in SPCR and the ODRn.Bi bit for I/O ports, the RSPI can switch pin states. Table 25.6 lists the relationship between pin states and bit settings. Setting the ODRn.Bi bit for an I/O port to 0 selects CMOS output; setting it to 1 selects open-drain output. The I/O port settings should follow this relationship.

Table 25.6 Relationship between Pin States and Bit Settings

|                                                                   |                  | Pin State*2                   |                               |  |
|-------------------------------------------------------------------|------------------|-------------------------------|-------------------------------|--|
| Mode                                                              | Pin              | ODRn.Bi Bit for I/O Ports = 0 | ODRn.Bi Bit for I/O Ports = 1 |  |
| Single-master mode (SPI operation)                                | RSPCKA           | CMOS output                   | Open-drain output             |  |
| (MSTR = 1, MODFEN = 0, SPMS = 0)                                  | SSLA0 to SSLA3   | CMOS output                   | Open-drain output             |  |
|                                                                   | MOSIA            | CMOS output                   | Open-drain output             |  |
|                                                                   | MISOA            | Input                         | Input                         |  |
| Multi-master mode (SPI operation)                                 | RSPCKA*3         | CMOS output/Hi-Z              | Open-drain output/Hi-Z        |  |
| (MSTR = 1, MODFEN = 1, SPMS = 0)                                  | SSLA0            | Input                         | Input                         |  |
|                                                                   | SSLA1 to SSLA3*3 | CMOS output/Hi-Z              | Open-drain output/Hi-Z        |  |
|                                                                   | MOSIA*3          | CMOS output/Hi-Z              | Open-drain output/Hi-Z        |  |
|                                                                   | MISOA            | Input                         | Input                         |  |
| Slave mode (SPI operation)                                        | RSPCKA           | Input                         | Input                         |  |
| (MSTR = 0, SPMS = 0)                                              | SSLA0            | Input                         | Input                         |  |
|                                                                   | SSLA1 to SSLA3*5 | Hi-Z* <sup>1</sup>            | Hi-Z*1                        |  |
|                                                                   | MOSIA            | Input                         | Input                         |  |
|                                                                   | MISOA*4          | CMOS output/Hi-Z              | Open-drain output/Hi-Z        |  |
| Master mode                                                       | RSPCKA           | CMOS output                   | Open-drain output             |  |
| (Clock synchronous operation)<br>(MSTR = 1, MODFEN = 0, SPMS = 1) | SSLA0 to SSLA3*5 | Hi-Z* <sup>1</sup>            | Hi-Z*1                        |  |
| (MOTX = 1, MODI EIV = 0, OF MO = 1)                               | MOSIA            | CMOS output                   | Open-drain output             |  |
|                                                                   | MISOA            | Input                         | Input                         |  |
| Slave mode                                                        | RSPCKA           | Input                         | Input                         |  |
| (Clock synchronous operation)<br>(MSTR = 0, SPMS = 1)             | SSLA0 to SSLA3*5 | Hi-Z*1                        | Hi-Z* <sup>1</sup>            |  |
| (Me : X = 0, 01 Me = 1)                                           | MOSIA            | Input                         | Input                         |  |
|                                                                   | MISOA            | CMOS output                   | Open-drain output             |  |

Note 1. This function is not supported in this mode.

The RSPI in single-master mode (SPI operation) or multi-master mode (SPI operation) determines MOSI signal values during the SSL negation period (including the SSL retention period during a burst transfer) according to MOIFE and MOIFV bit settings in SPPCR, as listed in Table 25.7.

Table 25.7 MOSI Signal Value Determination during SSL Negation Period

| MOIFE Bit | MOIFV Bit | MOSIA Signal Value during SSL Negation Period |  |
|-----------|-----------|-----------------------------------------------|--|
| 0         | 0, 1      | Final data from previous transfer             |  |
| 1         | 0         | Low                                           |  |
| 1         | 1         | High                                          |  |

Note 2. RSPI settings are not reflected in the multiplex pins for which the RSPI function is not selected.

Note 3. When SSLA0 is at the active level, the pin state is Hi-Z.

Note 4. When SSLA0 is at the non-active level or the SPCR.SPE bit is 0, the pin state is Hi-Z.

Note 5. These pins are available for use as I/O port pins.

# 25.3.3 RSPI System Configuration Examples

# 25.3.3.1 Single Master/Single Slave (with This MCU Acting as Master)

Figure 25.5 shows a single-master/single-slave RSPI system configuration example when this MCU is used as a master. In the single-master/single-slave configuration, the SSLA0 to SSLA3 output of this MCU (master) are not used. The SSL input of the SPI slave is fixed to the low level, and the SPI slave is maintained in a select state.\*

This MCU (master) drives the RSPCKA and MOSIA. The SPI slave drives the MISO.

Note 1. In the transfer format corresponding to the case where the SPCMDm.CPHA bit is 0, there are slave devices for which the SSL signal cannot be fixed to the active level. In situations where the SSL signal cannot be fixed, the SSLAi output of this MCU should be connected to the SSL input of the slave device.



Figure 25.5 Single-Master/Single-Slave Configuration Example (This MCU = Master)

# 25.3.3.2 Single Master/Single Slave (with This MCU Acting as Slave)

Figure 25.6 shows a single-master/single-slave RSPI system configuration example when this MCU is used as a slave. When this MCU is to operate as a slave, the SSLA0 pin is used as SSL input. The SPI master drives the RSPCK and MOSI. This MCU (slave) drives the MISOA.\*1

In the single-slave configuration in which the SPCMDm.CPHA bit is set to 1, the SSLA0 input of this MCU (slave) is fixed to the low level, this MCU (slave) is maintained in a select state, and in this manner it is possible to execute serial transfer (Figure 25.7).

Note 1. When SSLA0 is at the non-active level, the pin state is Hi-Z.



Figure 25.6 Single-Master/Single-Slave Configuration Example (This MCU = Slave, CPHA = 0)



Figure 25.7 Single-Master/Single-Slave Configuration Example (This MCU = Slave, CPHA = 1)

# 25.3.3.3 Single Master/Multi-Slave (with This MCU Acting as Master)

Figure 25.8 shows a single-master/multi-slave RSPI system configuration example when this MCU is used as a master. In the example of Figure 25.8, the RSPI system is comprised of this MCU (master) and four slaves (SPI slave 0 to SPI slave 3).

The RSPCKA and MOSIA outputs of this MCU (master) are connected to the RSPCK and MOSI inputs of SPI slave 0 to SPI slave 3. The MISO outputs of SPI slave 0 to SPI slave 3 are all connected to the MISOA input of this MCU (master). SSLA0 to SSLA3 outputs of this MCU (master) are connected to the SSL inputs of SPI slave 0 to SPI slave 3, respectively.

This MCU (master) drives RSPCKA, MOSIA, and SSLA0 to SSLA3. Of the SPI slave 0 to SPI slave 3, the slave that receives low-level input into the SSL input drives MISO.



Figure 25.8 Single-Master/Multi-Slave Configuration Example (This MCU = Master)

# 25.3.3.4 Single Master/Multi-Slave (with This MCU Acting as Slave)

Figure 25.9 shows a single-master/multi-slave RSPI system configuration example when this MCU is used as a slave. In the example of Figure 25.9, the RSPI system is comprised of an SPI master and two MCUs (slave X and slave Y). The SPCK and MOSI outputs of the SPI master are connected to the RSPCKA and MOSIA inputs of the MCUs (slave X and slave Y). The MISOA outputs of the MCUs (slave X and slave Y) are all connected to the MISO input of the SPI master. SSLX and SSLY outputs of the SPI master are connected to the SSLA0 inputs of the MCUs (slave X and slave Y), respectively.

The SPI master drives SPCK, MOSI, SSLX, and SSLY. Of the MCUs (slave X and slave Y), the slave that receives low-level input into the SSLA0 input drives MISOA.



Figure 25.9 Single-Master/Multi-Slave Configuration Example (This MCU = Slave)

# 25.3.3.5 Multi-Master/Multi-Slave (with This MCU Acting as Master)

Figure 25.10 shows a multi-master/multi-slave RSPI system configuration example when this MCU is used as a master. In the example of Figure 25.10, the RSPI system is comprised of two MCUs (master X and master Y) and two SPI slaves (SPI slave 1 and SPI slave 2).

The RSPCKA and MOSIA outputs of the MCUs (master X and master Y) are connected to the RSPCK and MOSI inputs of SPI slaves 1 and 2. The MISO outputs of SPI slaves 1 and 2 are connected to the MISOA inputs of the MCUs (master X and master Y). Any generic port Y output from this MCU (master X) is connected to the SSLA0 input of this MCU (master Y). Any generic port X output of this MCU (master Y) is connected to the SSLA0 input of this MCU (master X). The SSLA1 and SSLA2 outputs of the MCUs (master X and master Y) are connected to the SSL inputs of the SPI slaves 1 and 2. In this configuration example, since the system can be comprised solely of SSLA0 input, and SSLA1 and SSLA2 outputs for slave connections, the SSLA3 output of this MCU is not required.

This MCU drives RSPCKA, MOSIA, SSLA1, and SSLA2 when the SSLA0 input level is high. When the SSLA0 input level is low, this MCU detects a mode fault error, sets RSPCKA, MOSIA, SSLA1, and SSLA2 to Hi-Z, and releases the RSPI bus right to the other master. Of the SPI slaves 1 and 2, the slave that receives low-level input into the SSL input drives MISO.



Figure 25.10 Multi-Master/Multi-Slave Configuration Example (This MCU = Master)

# 25.3.3.6 Master (Clock Synchronous Operation)/Slave (Clock Synchronous Operation) (with This MCU Acting as Master)

Figure 25.11 shows a master (clock synchronous operation)/slave (clock synchronous operation) RSPI system configuration example when this MCU is used as a master. In the master (clock synchronous operation)/slave (clock synchronous operation) configuration, SSLA0 to SSLA3 of this MCU (master) are not used. This MCU (master) drives the RSPCKA and MOSIA. The SPI slave drives the MISO.



Figure 25.11 Master (Clock Synchronous Operation)/Slave (Clock Synchronous Operation) Configuration Example (This MCU = Master)

# 25.3.3.7 Master (Clock Synchronous Operation)/Slave (Clock Synchronous Operation) (with This MCU Acting as Slave)

Figure 25.12 shows a master (clock synchronous operation)/slave (clock synchronous operation) RSPI system configuration example when this MCU is used as a slave. When this MCU is to operate as a slave (clock synchronous operation), this MCU (slave) drives the MISOA and the SPI master drives the SPCK and MOSI. In addition, SSLA0 to SSLA3 of this MCU (slave) are not used.

Only in the single-slave configuration in which the SPCMDm.CPHA bit is set to 1, this MCU (slave) can execute serial transfer.



Figure 25.12 Master (Clock Synchronous Operation)/Slave (Clock Synchronous Operation) Configuration Example (This MCU = Slave, CPHA = 1)

# 25.3.4 Data Format

The RSPI's data format depends on the settings in RSPI command register m (SPCMDm) (m = 0 to 7) and the parity enable bit in RSPI control register 2 (SPCR2.SPPE). Regardless of whether the MSB or LSB is first, the RSPI treats the range from the LSB bit in the RSPI data register (SPDR) to the selected data length as transfer data. The format of one frame of data before or after transfer is shown below.

With Parity Disabled

When parity is disabled, transmission or reception of data proceeds with the length in bits selected in the RSPI data length setting bits in RSPI command register m (SPCMDm.SPB[3:0]).

# (b) With Parity Enabled

When parity is enabled, transmission or reception of data proceeds with the length in bits selected in the RSPI data length setting bits in RSPI command register m (SPCMDm.SPB[3:0]). In this case, however, the last bit is a parity bit.



Figure 25.13 Outline of the Data Format (with Parity Disabled/Enabled)

# 25.3.4.1 When Parity is Disabled (SPCR2.SPPE = 0)

When parity is disabled, data for transmission are copied to the shift register with no prior processing. A description of the connection between the RSPI data register (SPDR) and the shift register in terms of the combination of MSB or LSB first and data length is given below.

# (1) MSB First Transfer (32-Bit Data)

Figure 25.14 shows details of operations by the RSPI data register (SPDR) and the shift register in transfer with parity disabled, an RSPI data length of 32 bits, and MSB first selected.

In transmission, bits T31 to T00 from the current stage of the transmit buffer are copied to the shift register. Data for transmission are shifted out from the shift register in order from T31, through T30, and so on to T00.

In reception, received data are shifted in bit by bit through bit 0 of the shift register. When bits R31 to R00 have been collected after input of the required number of cycles of RSPCK, the value in the shift register is copied to the receive buffer.



Figure 25.14 MSB First Transfer (32-Bit Data, Parity Disabled)

# (2) MSB First Transfer (24-Bit Data)

Figure 25.15 shows details of operations by the RSPI data register (SPDR) and the shift register in transfer with parity disabled, 24 bits as the RSPI data length for an example that is not 32 bits, and MSB first selected.

In transmission, the lower-order 24 bits (T23 to T00) from the current stage of the transmit buffer are copied to the shift register. Data for transmission are shifted out from the shift register in order from T23, through T22, and so on to T00. In reception, received data are shifted in bit by bit through bit 0 of the shift register. When bits R23 to R00 have been collected after input of the required number of cycles of RSPCK, the value in the shift register is copied to the receive buffer. At this time, the higher-order 8 bits of the transmit buffer are stored in the higher-order 8 bits of the receive buffer. Writing 0 to bits T31 to T24 at the time of transmission leads to 0 being inserted in the higher-order 8 bits of the receive buffer.



Figure 25.15 MSB First Transfer (24-Bit Data, Parity Disabled)

# (3) LSB First Transfer (32-Bit Data)

Figure 25.16 shows details of operations by the RSPI data register (SPDR) and the shift register in transfer with parity disabled, an RSPI data length of 32 bits, and LSB first selected.

In transmission, bits T31 to T00 from the current stage of the transmit buffer are reordered bit by bit to obtain the order T00 to T31 for copying to the shift register. Data for transmission are shifted out from the shift register in order from T00, through T01, and so on to T31.

In reception, received data are shifted in bit by bit through bit 0 of the shift register. When bits R00 to R31 have been collected after input of the required number of cycles of RSPCK, the value in the shift register is copied to the receive buffer.



Figure 25.16 LSB First Transfer (32-Bit Data, Parity Disabled)

# (4) LSB First Transfer (24-Bit Data)

Figure 25.17 shows details of operations by the RSPI data register (SPDR) and the shift register in transfer with parity disabled, 24 bits as the RSPI data length for an example that is not 32 bits, and LSB first selected.

In transmission, the lower-order 24 bits (T23 to T00) from the current stage of the transmit buffer are reordered bit by bit to obtain the order T00 to T23 for copying to the shift register. Data for transmission are shifted out from the shift register in order from T00, through T01, and so on to T23.

In reception, received data are shifted in bit by bit through bit 8 of the shift register. When bits R00 to R23 have been collected after input of the required number of cycles of RSPCK, the value in the shift register is copied to the receive buffer.

At this time, the higher-order 8 bits of the transmit buffer are stored in the higher-order 8 bits of the receive buffer. Writing 0 to bits T31 to T24 at the time of transmission leads to 0 being inserted in the higher-order 8 bits of the receive buffer.



Figure 25.17 LSB First Transfer (24-Bit Data, Parity Disabled)

# 25.3.4.2 When Parity is Enabled (SPCR2.SPPE = 1)

When parity is enabled, the lowest-order bit of the data for transmission becomes a parity bit. Hardware calculates the value of the parity bit.

# (1) MSB First Transfer (32-Bit Data)

Figure 25.18 shows details of operations by the RSPI data register (SPDR) and the shift register in transfer with parity enabled, an RSPI data length of 32 bits, and MSB first selected.

In transmission, the value of the parity bit (P) is calculated from bits T31 to T01. This replaces the final bit, T00, and the whole is copied to the shift register. Data are transmitted in the order T31, T30, ..., T01, and P.

In reception, received data are shifted in bit by bit through bit 0 of the shift register. When bits R31 to P have been collected after input of the required number of cycles of RSPCK, the value in the shift register is copied to the receive buffer. On copying of data to the shift register, the data from R31 to P are checked by judging the parity.



Figure 25.18 MSB First Transfer (32-Bit Data, Parity Enabled)

# (2) MSB First Transfer (24-Bit Data)

Figure 25.19 shows details of operations by the RSPI data register (SPDR) and the shift register in transfer with parity enabled, 24 bits as the RSPI data length for an example that is not 32 bits, and MSB first selected.

In transmission, the value of the parity bit (P) is calculated from bits T23 to T01. This replaces the final bit, T00, and the whole is copied to the shift register. Data are transmitted in the order T23, T22, ..., T01, and P.

In reception, received data are shifted in bit by bit through bit 0 of the shift register. When bits R23 to P have been collected after input of the required number of cycles of RSPCK, the value in the shift register is copied to the receive buffer. On copying of data to the shift register, the data from R23 to P are checked by judging the parity. At this time, the higher-order 8 bits of the transmit buffer are stored in the higher-order 8 bits of the receive buffer. Writing 0 to bits T31 to T24 at the time of transmission leads to 0 being inserted in the higher-order 8 bits of the receive buffer.



Figure 25.19 MSB First Transfer (24-Bit Data, Parity Enabled)

# (3) LSB First Transfer (32-Bit Data)

Figure 25.20 shows details of operations by the RSPI data register (SPDR) and the shift register in transfer with parity enabled, an RSPI data length of 32 bits, and LSB first selected.

In transmission, the value of the parity bit (P) is calculated from bits T30 to T00. This replaces the final bit, T31, and the whole is copied to the shift register. Data are transmitted in the order T00, T01, ..., T30, and P.

In reception, received data are shifted in bit by bit through bit 0 of the shift register. When bits R00 to P have been collected after input of the required number of cycles of RSPCK, the value in the shift register is copied to the receive buffer. On copying of data to the shift register, the data from R00 to P are checked by judging the parity.



Figure 25.20 LSB First Transfer (32-Bit Data, Parity Enabled)

# (4) LSB First Transfer (24-Bit Data)

Figure 25.21 shows details of operations by the RSPI data register (SPDR) and the shift register in transfer with parity enabled, 24 bits as the RSPI data length for an example that is not 32 bits, and LSB first selected.

In transmission, the value of the parity bit (P) is calculated from bits T22 to T00. This replaces the final bit, T23, and the whole is copied to the shift register. Data are transmitted in the order T00, T01, ..., T22, and P.

In reception, received data are shifted in bit by bit through bit 8 of the shift register. When bits R00 to P have been collected after input of the required number of cycles of RSPCK, the value in the shift register is copied to the receive buffer. On copying of data to the shift register, the data from R00 to P are checked by judging the parity. At this time, the higher-order 8 bits of the transmit buffer are stored in the higher-order 8 bits of the receive buffer. Writing 0 to bits T31 to T24 at the time of transmission leads to 0 being inserted in the higher-order 8 bits of the receive buffer.



Figure 25.21 LSB First Transfer (24-Bit Data, Parity Enabled)

#### 25.3.5 Transfer Format

#### 25.3.5.1 CPHA = 0

Figure 25.22 shows a sample transfer format for the serial transfer of 8-bit data when the SPCMDm.CPHA bit is 0. Note that clock synchronous operation (the SPCR.SPMS bit is 1) should not performed when the RSPI operates in slave mode (SPCR.MSTR = 0) and the CPHA bit is 0. In Figure 25.22, RSPCKA (CPOL = 0) indicates the RSPCKA signal waveform when the SPCMDm.CPOL bit is 0; RSPCKA (CPOL = 1) indicates the RSPCKA signal waveform when the CPOL bit is 1. The sampling timing represents the timing at which the RSPI fetches serial transfer data into the shift register. The I/O directions of the signals depend on the RSPI settings. For details, refer to section 25.3.2, Controlling RSPI Pins.

When the SPCMDm.CPHA bit is 0, the driving of valid data to the MOSIA and MISOA signals commences at an SSLAi signal assertion timing. The first RSPCKA signal change timing that occurs after the SSLAi signal assertion becomes the first transfer data fetch timing. After this timing, data is sampled at every 1 RSPCK cycle. The change timing for MOSIA and MISOA signals is 1/2 RSPCK cycles after the transfer data fetch timing. The CPOL bit setting does not affect the RSPCKA signal operation timing; it only affects the signal polarity.

t1 denotes a period from an SSLAi signal assertion to RSPCKA oscillation (RSPCK delay). t2 denotes a period from the termination of RSPCKA oscillation to an SSLAi signal negation (SSL negation delay). t3 denotes a period in which SSLAi signal assertion is suppressed for the next transfer after the end of serial transfer (next-access delay). t1, t2, and t3 are controlled by a master device running on the RSPI system. For a description of t1, t2, and t3 when the RSPI of this MCU is in master mode, refer to section 25.3.10.1, Master Mode Operation.



Figure 25.22 RSPI Transfer Format (CPHA = 0)

# 25.3.5.2 CPHA = 1

Figure 25.23 shows a sample transfer format for the serial transfer of 8-bit data when the SPCMDm.CPHA bit is 1. However, when the SPCR.SPMS bit is 1, the SSLAi signals are not used, and only the three signals RSPCKA, MOSIA, and MISOA handle communications. In Figure 25.23, RSPCK (CPOL = 0) indicates the RSPCKA signal waveform when the SPCMDm.CPOL bit is 0; RSPCKA (CPOL = 1) indicates the RSPCKA signal waveform when the CPOL bit is 1. The sampling timing represents the timing at which the RSPI fetches serial transfer data into the shift register. The I/O directions of the signals depend on the RSPI mode (master or slave). For details, refer to section 25.3.2, Controlling RSPI Pins.

When the SPCMDm.CPHA bit is 1, the driving of invalid data to the MISOA signal commences at an SSLAi signal assertion timing. The output of valid data to the MOSIA and MISOA signals commences at the first RSPCKA signal change timing that occurs after the SSLAi signal assertion. After this timing, data is updated at every 1 RSPCK cycle. The transfer data fetch timing is 1/2 RSPCK cycles after the data update timing. The SPCMDm.CPOL bit setting does not affect the RSPCKA signal operation timing; it only affects the signal polarity.

t1, t2, and t3 are the same as those in the case of CPHA = 0. For a description of t1, t2, and t3 when the RSPI of this MCU is in master mode, refer to section 25.3.10.1, Master Mode Operation.



Figure 25.23 RSPI Transfer Format (CPHA = 1)

# 25.3.6 Communications Operating Mode

Full-duplex synchronous serial communications or transmit operations only can be selected by the communications operating mode select bit (SPCR.TXMD). The SPDR access shown in Figure 25.24 and Figure 25.25 indicate the condition of access to the SPDR register, where W denotes a write cycle.

# 25.3.6.1 Full-Duplex Synchronous Serial Communications (SPCR.TXMD = 0)

Figure 25.24 shows an example of operation when the communications operating mode select bit (SPCR.TXMD) is set to 0. In the example in Figure 25.24, the RSPI performs an 8-bit serial transfer in which the SPDCR.SPFC[1:0] bits are 00b, the SPCMDm.CPHA bit is 1, and the SPCMDm.CPOL bit is 0. The numbers given under the RSPCKA waveform represent the number of RSPCK cycles (i.e., the number of transferred bits).



Figure 25.24 Operation Example of SPCR.TXMD = 0

The operation of the flags at timings shown in steps (1) and (2) in the figure is described below.

- (1) When a serial transfer ends with the receive buffer of SPDR empty, the RSPI generates a receive buffer full interrupt request (SPRI) (sets the SPSR.SPRF flag to 1) and copies the received data in the shift register to the receive buffer.
- (2) When a serial transfer ends with the receive buffer of SPDR holding data that was received in the previous serial transfer, the RSPI sets the SPSR.OVRF flag to 1 and discards the received data in the shift register.

When full-duplex synchronous serial communications (SPCR.TXMD = 0) is selected, reception occurs simultaneously with transmit operations. As such, the SPRF and OVRF flags in the SPSR register become 1 at the timing described in (1) and (2), respectively, according to the state of the receive buffer.

# 25.3.6.2 Transmit Operations Only (SPCR.TXMD = 1)

Figure 25.25 shows an example of operation when the communications operating mode select bit (SPCR.TXMD) is set to 1. In the example in Figure 25.25, the RSPI performs an 8-bit serial transfer in which the SPDCR.SPFC[1:0] bits are 00b, the SPCMDm.CPHA bit is 1, and the SPCMDm.CPOL bit is 0. The numbers given under the RSPCKA waveform represent the number of RSPCK cycles (i.e., the number of transferred bits).



Figure 25.25 Operation Example of SPCR.TXMD = 1

The operation of the flags at timings shown in steps (1) to (3) in the figure is described below.

- (1) Make sure there is no data left in the receive buffer and the SPSR.SPRF, OVRF flags are 0 before entering the mode of transmit operations only (SPCR.TXMD = 1).
- (2) When a serial transfer ends with the receive buffer of SPDR empty, if the mode of transmit operations only is selected (SPCR.TXMD = 1), the SPRF flag remains 0 and the RSPI does not copy the data from the shift register to the receive buffer.
- (3) Since the receive buffer of SPDR does not hold data that was received in the previous serial transfer, even when a serial transfer ends, the SPSR.OVRF flag retains the value of 0, and the data in the shift register is not copied to the receive buffer.

When performing transmit operations only (SPCR.TXMD = 1), the RSPI transmits data but does not receive data. Therefore, the SPSR.SPRF, OVRF flags remain 0 at the timings of (1) to (3).

# 25.3.7 Transmit Buffer Empty/Receive Buffer Full Interrupts

Figure 25.26 shows an example of operation of the transmit buffer empty interrupt (SPTI) and the receive buffer full interrupt (SPRI). The SPDR register access shown in Figure 25.26 indicates the condition of access to the SPDR register, where W denotes a write cycle, and R a read cycle. In the example in Figure 25.26, the RSPI performs an 8-bit serial transfer in which the SPCR.TXMD bit is 0, the SPDCR.SPFC[1:0] bits are 00b, the SPCMDm.CPHA bit is 1, and the SPCMDm.CPOL bit is 0. The numbers given under the RSPCKA waveform represent the number of RSPCK cycles (i.e., the number of transferred bits).



Figure 25.26 Operation Example of SPTI and SPRI Interrupts

The operation of the interrupts at timings shown in steps (1) to (5) in the figure is described below.

- (1) When transmit data is written to SPDR when the transmit buffer of SPDR is empty (data for the next transfer is not set), the RSPI writes data to the transmit buffer and sets the SPSR.SPTEF flag to 0.
- (2) If the shift register is empty, the RSPI copies the data from the transmit buffer to the shift register and generates a transmit buffer empty interrupt request (SPTI) and sets the SPSR.SPTEF flag to 1. How a serial transfer is started depends on the mode of the RSPI. For details, refer to section 25.3.10, SPI Operation, and section 25.3.11, Clock Synchronous Operation.
- (3) When transmit data is written to SPDR in the transmit buffer empty interrupt routine or in the transmit buffer empty detecting process by polling the SPTEF flag, the data is transferred to the transmit buffer and the SPSR.SPTEF flag becomes 0. Because the data being transmitted is stored in the shift register, the RSPI does not copy the data from the transmit buffer to the shift register.
- (4) When the serial transfer ends with the receive buffer of SPDR being empty, the RSPI copies the receive data from the shift register to the receive buffer, generates a receive buffer full interrupt request (SPRI), and sets the SPSR.SPRF flag to 1. Since the shift register becomes empty upon completion of serial transfer, when the transmit buffer had been full before the serial transfer ended, the RSPI sets the SPSR.SPTEF flag to 1 and copies the data from the transmit buffer to the shift register. Even when received data is not copied from the shift register to the receive buffer in an overrun error status, upon completion of the serial transfer, the RSPI determines that the shift register is empty, thus data transfer from the transmit buffer to the shift register is enabled.

(5) When SPDR is read in the receive buffer full interrupt routine or in the receive buffer full detecting process by polling the SPRF flag, the receive data can be read. When the receive data is read, the SPRF flag becomes 0.

If transmit data is written to SPDR while the transmit buffer holds data that has not yet been transmitted (the SPTEF flag is 0), the RSPI does not update the data in the transmit buffer. Transmit data should be written to SPDR in the transmit buffer empty interrupt request routine or in the transmit buffer empty detecting process by polling the SPTEF flag. To use a transmit buffer empty interrupt, set the SPTIE bit in SPCR to 1.

When setting the SPCR.SPE bit to 0 (RSPI disabled), the SPCR.SPTIE bit should also be set to 0. Otherwise (if the SPCR.SPE bit is 0 and the SPCR.SPTIE is 1), a transmit buffer empty interrupt request will occur.

When serial transfer ends with the receive buffer being full (the SPRF flag is 1), the RSPI does not copy data from the shift register to the receive buffer, and detects an overrun error (refer to section 25.3.8, Error Detection). To prevent a receive data overrun error, read the received data using a receive buffer full interrupt request before the next serial transfer ends. To use an RSPI receive buffer full interrupt, set the SPCR.SPRIE bit to 1.

Transmit and receive interrupts or the corresponding IRn.IR flags (where n is the interrupt vector number) in the ICU can be used to confirm the states of the transmit and receive buffers. Refer to section 14, Interrupt Controller (ICUb), for the interrupt vector numbers. The status of the transmit and receive buffers can be also confirmed by the SPTEF and SPRF flags.

#### 25.3.8 Error Detection

In the normal RSPI serial transfer, the data written to the transmit buffer of SPDR is transmitted, and the received data can be read from the receive buffer of SPDR. If access is made to SPDR, depending on the status of the transmit/receive buffer or the status of the RSPI at the beginning or end of serial transfer, in some cases non-normal transfers can be executed.

If a non-normal transfer operation occurs, the RSPI detects the event as an overrun error, parity error, or mode fault error. Table 25.8 lists the relationship between non-normal transfer operations and the RSPI's error detection function.

Table 25.8 Relationship between Non-Normal Transfer Operations and RSPI Error Detection Function

|   | Occurrence Condition                                                                                                                       | RSPI Operation                                                                                                                                                                                                     | Error Detection  |
|---|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| 1 | SPDR is written when the transmit buffer is full.                                                                                          | <ul><li>The contents of the transmit buffer are kept.</li><li>Missing write data.</li></ul>                                                                                                                        | None             |
| 2 | SPDR is read when the receive buffer is empty.                                                                                             | Data received previously is output to the bus.                                                                                                                                                                     | None             |
| 3 | Serial transfer is started in slave mode when transmit data is still not loaded on the shift register.                                     | Data received in previous serial transfer is transmitted.                                                                                                                                                          | None             |
| 4 | Serial transfer terminates when the receive buffer is full.                                                                                | <ul><li>The contents of the receive buffer are kept.</li><li>Missing receive data.</li></ul>                                                                                                                       | Overrun error    |
| 5 | An incorrect parity bit is received when performing full-<br>duplex synchronous serial communications with the<br>parity function enabled. | The parity error flag is asserted.                                                                                                                                                                                 | Parity error     |
| 6 | The SSLA0 input signal is asserted when the serial transfer is idle in multi-master mode.                                                  | <ul> <li>Driving of the RSPCKA, MOSIA, SSLA1 to<br/>SSLA3 output signals is stopped.</li> <li>RSPI function is disabled.</li> </ul>                                                                                | Mode fault error |
| 7 | The SSLA0 input signal is asserted during serial transfer in multi-master mode.                                                            | <ul> <li>Serial transfer is suspended.</li> <li>Missing transmit/receive data.</li> <li>Driving of the RSPCKA, MOSIA, SSLA1 to<br/>SSLA3 output signals is stopped.</li> <li>RSPI function is disabled.</li> </ul> | Mode fault error |
| 8 | The SSLA0 input signal is negated during serial transfer in slave mode.                                                                    | <ul> <li>Serial transfer is suspended.</li> <li>Missing transmit/receive data.</li> <li>Driving of the MISOA output signal is stopped.</li> <li>RSPI function is disabled.</li> </ul>                              | Mode fault error |

On operation 1 described in Table 25.8, the RSPI does not detect an error. To prevent data omission during the writing to SPDR, the SPDR register should be written when a transmit buffer empty interrupt request occurs or while the SPSR.SPTEF flag is 1.

Likewise, the RSPI does not detect an error on operation 2. To prevent extraneous data from being read, the SPDR register should be read when an RSPI receive buffer full interrupt request occurs or while the SPSR.SPRF flag is 1. Similarly, the RSPI does not detect an error on operation 3. In a serial transfer that was started before the shift register was updated, the RSPI sends the data that was received in the previous serial transfer, and does not treat the operation indicated in 3 as an error. Note that the received data from the previous serial transfer is retained in the receive buffer of SPDR, thus it can be correctly read (if SPDR is not read before the end of the serial transfer, an overrun error may occur). An overrun error shown in 4 is described in section 25.3.8.1, Overrun Error. A parity error shown in 5 is described in section 25.3.8.2, Parity Error. A mode fault error shown in 6 to 8 is described in section 25.3.8.3, Mode Fault Error. For the transmit and receive interrupts, refer to section 25.3.7, Transmit Buffer Empty/Receive Buffer Full Interrupts.

#### 25.3.8.1 Overrun Error

If a serial transfer ends when the receive buffer of SPDR is full, the RSPI detects an overrun error, and sets the SPSR.OVRF flag to 1. When the OVRF flag is 1, the RSPI does not copy data from the shift register to the receive buffer so that the data prior to the occurrence of the error is retained in the receive buffer. To set the OVRF flag to 0, write 0 to the OVRF flag after the CPU has read SPSR with the OVRF flag set to 1.

Figure 25.27 shows an example of operations of the SPRF and OVRF flags. The SPSR and SPDR accesses shown in Figure 25.27 indicate the condition of accesses to SPSR and SPDR, respectively, where W denotes a write cycle, and R a read cycle. In the example in Figure 25.27, the RSPI performs an 8-bit serial transfer in which the SPCMDm.CPHA bit is 1 and the SPCMDm.CPOL bit is 0. The numbers given under the RSPCKA waveform represent the number of RSPCK cycles (i.e., the number of transferred bits).



Figure 25.27 Operation Example of SPRF and OVRF Flags

The operation of the flags at the timing shown in steps (1) to (4) in the figure is described below.

- (1) If a serial transfer terminates with the receive buffer full (the SPRF flag is 1), the RSPI detects an overrun error, and sets the OVRF flag to 1. The RSPI does not copy the data in the shift register to the receive buffer. Even if the SPPE bit is 1, parity errors are not detected. In master mode, the RSPI copies the pointer value to SPCMDm register to the SPSSR.SPECM[2:0] bits.
- (2) When SPDR is read, the RSPI outputs the data in the receive buffer. At this time the SPRF flag becomes 0. Even if the receive buffer becomes empty, the OVRF flag does not become 0.
- (3) If the serial transfer ends with the OVRF flag being 1 (an overrun error occurs), the RSPI does not copy the data in the shift register to the receive buffer (the SPRF flag remains 0). A receive buffer full interrupt is not generated. Even if the SPPE bit is 1, parity errors are not detected. When in master mode, the RSPI does not update the SPSSR.SPECM[2:0] bits. When in an overrun error state and the RSPI does not copy the received data from the shift register to the receive buffer, upon termination of the serial transfer, the RSPI determines that the shift register is empty; in this manner, data transfer from the transmit buffer to the shift register is enabled.
- (4) If 0 is written to the OVRF flag after SPSR is read when the OVRF flag is 1, the OVRF flag is set to 0.

The occurrence of an overrun can be checked either by reading SPSR or by using an RSPI error interrupt and reading SPSR. When executing a serial transfer, measures should be taken to ensure the early detection of overrun errors, such as reading SPSR immediately after SPDR is read. When the RSPI is used in master mode, the pointer value to SPCMDm register at the occurrence of the error can be checked by reading the SPSSR.SPECM[2:0] bits.

If an overrun error occurs and the OVRF flag is set to 1, normal reception operations cannot be performed until the OVRF flag is set to 0.

# 25.3.8.2 Parity Error

If full-duplex synchronous serial communications is performed with the SPCR.TXMD bit set to 0 and the SPCR2.SPPE bit set to 1, when serial transfer ends, the RSPI checks whether there are parity errors. Upon detecting a parity error in the received data, the RSPI sets the SPSR.PERF flag to 1. Since the RSPI does not copy the data in the shift register to the receive buffer when the SPSR.OVRF flag is set to 1, parity error detection is not performed for the received data. To set the PERF flag to 0, write 0 to the PERF flag after SPSR register is read with the PERF flag set to 1.

Figure 25.28 shows an example of operation of the OVRF and PERF flags. The SPSR access shown in Figure 25.28 indicates the condition of access to SPSR register, where W denotes a write cycle, and R a read cycle. In the example of Figure 25.28, full-duplex synchronous serial communications is performed while the SPCR.TXMD bit is 0 and the SPCR2.SPPE bit is 1. The RSPI performs an 8-bit serial transfer in which the SPCMDm.CPHA bit is 1 and the SPCMDm.CPOL bit is 0. The numbers given under the RSPCKA waveform represent the number of RSPCK cycles (i.e., the number of transferred bits).



Figure 25.28 Operation Example of PERF Flag

The operation of the flags at the timing shown in steps (1) to (3) in the figure is described below.

- (1) If a serial transfer terminates with the RSPI not detecting an overrun error, the RSPI copies the data in the shift register to the receive buffer. The RSPI judges the received data at this timing, and sets the PERF flag to 1 if a parity error is detected. In master mode, the RSPI copies the pointer value to SPCMDm register to the SPSSR.SPECM[2:0] bits.
- (2) If 0 is written to the PERF flag after SPSR register is read when the PERF flag is 1, the PERF flag is set to 0.
- (3) When the RSPI detects an overrun error and serial transfer is terminated, the data in the shift register is not copied to the receive buffer. The RSPI does not perform parity error detection at this timing.

The occurrence of a parity error can be checked either by reading the SPSR register or by using an RSPI error interrupt and reading the SPSR register. When executing a serial transfer, measures should be taken to ensure the early detection of parity errors, such as reading SPSR. When the RSPI is used in master mode, the pointer value to SPCMDm register at the occurrence of the error can be checked by reading the SPSSR.SPECM[2:0] bits.

#### 25.3.8.3 Mode Fault Error

The RSPI operates in multi-master mode when the SPCR.MSTR bit is 1, the SPCR.SPMS bit is 0, and the SPCR.MODFEN bit is 1. If the active level is input with respect to the SSLA0 input signal of the RSPI in multi-master mode, the RSPI detects a mode fault error irrespective of the status of the serial transfer, and sets the SPSR.MODF flag to 1. Upon detecting the mode fault error, the RSPI copies the value of the pointer to SPCMDm to the SPSSR.SPECM[2:0] bits. The active level of the SSLA0 signal is determined by the SSLP.SSL0P bit.

When the MSTR bit is 0, the RSPI operates in slave mode. The RSPI detects a mode fault error if the MODFEN bit of the RSPI in slave mode is 1, and the SPMS bit is 0, and if the SSLA0 input signal is negated during the serial transfer period (from the time the driving of valid data is started to the time the final valid data is fetched).

Upon detecting a mode fault error, the RSPI stops driving of the output signals and clears the SPCR.SPE bit to 0 (refer to section 25.3.9, Initializing RSPI). In the case of multi-master configuration, detection of a mode fault error is used to stop driving of the output signals and the RSPI function, which allows the master right to be released.

The occurrence of a mode fault error can be checked either by reading SPSR or by using an RSPI error interrupt and reading SPSR. Detecting mode fault errors without utilizing the RSPI error interrupt requires polling of SPSR. When using the RSPI in master mode, the pointer value to SPCMDm register at the occurrence of the error can be checked by reading the SPSSR.SPECM[2:0] bits.

When the MODF flag is 1, writing of the value 1 to the SPE bit is ignored by the RSPI. To enable the RSPI function after the detection of a mode fault error, set the MODF flag to 0.

# 25.3.9 Initializing RSPI

If 0 is written to the SPCR.SPE bit or the RSPI sets the SPE bit to 0 because of the detection of a mode fault error, the RSPI disables the RSPI function, and initializes some of the module functions. When a system reset is generated, the RSPI initializes all of the module functions. The following describes initialization by the clearing of the SPCR.SPE bit and initialization by a system reset.

# 25.3.9.1 Initialization by Clearing the SPE Bit

When the SPCR.SPE bit is set to 0, the RSPI performs the following initialization:

- Suspending any serial transfer that is being executed
- Stopping the driving of output signals (Hi-Z) in slave mode
- Initializing the internal state of the RSPI
- Initializing the transmit buffer of the RSPI (Set the SPTEF flag to 1)

Initialization by the clearing of the SPE bit does not initialize the control bits of the RSPI. For this reason, the RSPI can be started in the same transfer mode as prior to the initialization if the SPE bit is set to 1 again.

The SPSR.SPRF, SPSR.OVRF, SPSR.MODF, and SPSR.PERF flags are not initialized, nor is the value of the RSPI sequence status register (SPSSR) initialized. For this reason, even after the RSPI is initialized, data from the receive buffer can be read in order to check the status of error occurrence during an RSPI transfer.

The transmit buffer is initialized to an empty state (the SPTEF flag is 1). Therefore, if the SPCR.SPTIE bit is set to 1 after RSPI initialization, a transmit buffer empty interrupt is generated. When the RSPI is initialized, in order to disable any transmit buffer empty interrupt, 0 should be written to the SPTIE bit simultaneously with the writing of 0 to the SPE bit.

# 25.3.9.2 System Reset

The initialization by a system reset completely initializes the RSPI through the initialization of all bits for controlling the RSPI, initialization of the status bits, and initialization of data registers, in addition to the requirements described in section 25.3.9.1, Initialization by Clearing the SPE Bit.

# 25.3.10 SPI Operation

# 25.3.10.1 Master Mode Operation

The only difference between single-master mode operation and multi-master mode operation lies in mode fault error detection (refer to section 25.3.8, Error Detection). When operating in single-master mode, the RSPI does not detect mode fault errors whereas the RSPI running in multi-master mode does detect mode fault errors. This section explains operations that are common to single-master mode and multi-master mode.

#### (1) Starting a Serial Transfer

The RSPI updates the data in the transmit buffer (SPTX) when data is written to the RSPI data register (SPDR) with the RSPI transmit buffer being empty (the SPTEF flag is 1 and data for the next transfer is not set). When the shift register is empty after the number of frames set in the SPDCR.SPFC[1:0] bits are written to the SPDR, the RSPI copies data from the transmit buffer to the shift register and starts serial transfer. Upon copying transmit data to the shift register, the RSPI changes the status of the shift register to "full", and upon termination of serial transfer, it changes the status of the shift register to "empty". The status of the shift register cannot be referenced.

For details on the RSPI transfer format, refer to section 25.3.5, Transfer Format. The polarity of the SSLAi output pins depends on the SSLP register settings.

#### (2) Terminating a Serial Transfer

Irrespective of the SPCMDm.CPHA bit, the RSPI terminates the serial transfer after transmitting an RSPCKA edge corresponding to the final sampling timing. If free space is available in the receive buffer (SPRX) (the SPRF flag is 0), upon termination of serial transfer, the RSPI copies data from the shift register to the receive buffer of the SPDR register. It should be noted that the final sampling timing varies depending on the bit length of transfer data. In master mode, the RSPI data length depends on the SPCMDm.SPB[3:0] bit setting. The polarity of the SSLAi output pin depends on the SSLP register settings.

For details on the RSPI transfer format, refer to section 25.3.5, Transfer Format.

#### (3) Sequence Control

The transfer format that is employed in master mode is determined by SPSCR, SPCMDm, SPBR, SPCKD, SSLND, and SPND registers.

SPSCR is a register used to determine the sequence configuration for serial transfers that are executed by the RSPI in master mode. The following items are set in SPCMDm register: SSLAi pin output signal value, MSB/LSB first, data length, some of the bit rate settings, RSPCK polarity/phase, whether SPCKD is to be referenced, whether SSLND is to be referenced, and whether SPND is to be referenced. SPBR holds some of the bit rate settings; SPCKD, an RSPI clock delay value; SSLND, an SSL negation delay; and SPND, a next-access delay value.

According to the sequence length that is assigned to SPSCR, the RSPI makes up a sequence comprised of a part or all of SPCMDm register. The RSPI contains a pointer to the SPCMDm register that makes up the sequence. The value of this pointer can be checked by reading the SPSSR.SPCP[2:0] bits. When the SPCR.SPE bit is set to 1 and the RSPI function is enabled, the RSPI loads the pointer to the commands in SPCMD0, and incorporates the SPCMD0 settings into the transfer format at the beginning of serial transfer. The RSPI increments the pointer each time the next-access delay period for a data transfer ends. Upon completion of the serial transfer that corresponds to the final command comprising the sequence, the RSPI sets the pointer in SPCMD0, and in this manner the sequence is executed repeatedly.



Figure 25.29 Procedure for Determining the Form of Serial Transfer in Master Mode

In this section, a frame is the combination of the data (SPDR) and the settings (SPCMDm).



Figure 25.30 Concept of a Frame

Figure 25.31 shows the relationship between the command and the transmit and receive buffers in the sequence of operations specified by the settings in Table 25.4.



Figure 25.31 Correspondence between the RSPI Command Register and Transmit/Receive Buffers in Sequence Operations

#### (4) Burst Transfer

If the SPCMDm.SSLKP bit that the RSPI references during the current serial transfer is 1, the RSPI keeps the SSLAi signal level during the serial transfer until the beginning of the SSLAi signal assertion for the next serial transfer. If the SSLAi signal level for the next serial transfer is the same as the SSLAi signal level for the current serial transfer, the RSPI can execute continuous serial transfers while keeping the SSLAi signal assertion status (burst transfer). Figure 25.32 shows an example of an SSLAi signal operation for the case where a burst transfer is implemented using SPCMD0 and SPCMD1 register settings. The text below explains the RSPI operations (1) to (7) as shown in Figure 25.32. It should be noted that the polarity of the SSLAi output signal depends on the SSLP register settings.



Figure 25.32 Example of Burst Transfer Operation Using SSLKP Bit

- (1) Based on SPCMD0, the RSPI asserts the SSLAi signal and inserts RSPCK delays.
- (2) The RSPI executes serial transfers according to SPCMD0.
- (3) The RSPI inserts SSL negation delays.
- (4) Since the SPCMD0.SSLKP bit is 1, the RSPI keeps the SSLAi signal value on SPCMD0. This period is sustained, at the shortest, for a period equal to the next-access delay of SPCMD0. If the shift register is empty after the passage of a minimum period, this period is sustained until the transmit data is stored in the shift register for the next transfer.
- (5) Based on SPCMD1, the RSPI asserts the SSLAi signal and inserts RSPCK delays.
- (6) The RSPI executes serial transfers according to SPCMD1.
- (7) Because the SPCMD1.SSLKP bit is 0, the RSPI negates the SSLAi signal. In addition, a next-access delay is inserted according to SPCMD1.

If the SSLAi signal output settings in the SPCMDm register in which 1 is assigned to the SSLKP bit are different from the SSLAi signal output settings in the SPCMDm register to be used in the next transfer, the RSPI switches the SSLAi signal status to SSLAi signal assertion ((5) in Figure 25.32) corresponding to the command for the next transfer. Note that if such an SSLAi signal switching occurs, the slaves that drive the MISOA signal compete, and collision of signal levels may occur.

The RSPI in master mode references the SSLAi signal operation within the module for the case where the SSLKP bit is not used. Even when the SPCMDm.CPHA bit is 0, the RSPI can accurately start serial transfers by using the SSLAi signal assertion for the next transfer that is detected internally.

# (5) RSPCK Delay (t1)

The RSPCK delay value of the RSPI in master mode depends on the SPCMDm.SCKDEN bit setting and the SPCKD register setting. The RSPI determines the SPCMDm register to be referenced during serial transfer by pointer control, and determines an RSPCK delay value during serial transfer by using the SPCMDm.SCKDEN bit and SPCKD, as listed in Table 25.9. For a definition of RSPCK delay, refer to section 25.3.5, Transfer Format.

Table 25.9 Relationship among SCKDEN Bit, SPCKD, and RSPCK Delay Value

| SPCMDm.SCKDEN Bit | SPCKD.SCKDL[2:0] Bits | RSPCK Delay Value |
|-------------------|-----------------------|-------------------|
| 0                 | 000b to 111b          | 1 RSPCK           |
| 1                 | 000b                  | 1 RSPCK           |
|                   | 001b                  | 2 RSPCK           |
|                   | 010b                  | 3 RSPCK           |
|                   | 011b                  | 4 RSPCK           |
|                   | 100b                  | 5 RSPCK           |
|                   | 101b                  | 6 RSPCK           |
|                   | 110b                  | 7 RSPCK           |
|                   | 111b                  | 8 RSPCK           |

# (6) SSL Negation Delay (t2)

The SSL negation delay value of the RSPI in master mode depends on the SPCMDm.SLNDEN bit setting and the SSLND register setting. The RSPI determines the SPCMDm register to be referenced during serial transfer by pointer control, and determines an SSL negation delay value during serial transfer by using the SPCMDm.SLNDEN bit and SSLND, as listed in Table 25.10. For a definition of SSL negation delay, refer to section 25.3.5, Transfer Format.

Table 25.10 Relationship among SLNDEN Bit, SSLND, and SSL Negation Delay Value

| SPCMDm.SLNDEN Bit | SSLND.SLNDL[2:0] Bits | SSL Negation Delay Value |  |
|-------------------|-----------------------|--------------------------|--|
| 0                 | 000b to 111b          | 1 RSPCK                  |  |
| 1                 | 000b                  | 1 RSPCK                  |  |
|                   | 001b                  | 2 RSPCK                  |  |
|                   | 010b                  | 3 RSPCK                  |  |
|                   | 011b                  | 4 RSPCK                  |  |
|                   | 100b                  | 5 RSPCK                  |  |
|                   | 101b                  | 6 RSPCK                  |  |
|                   | 110b                  | 7 RSPCK                  |  |
|                   | 111b                  | 8 RSPCK                  |  |

# (7) Next-Access Delay (t3)

The next-access delay value of the RSPI in master mode depends on the SPCMDm.SPNDEN bit setting and the SPND setting. The RSPI determines the SPCMDm register to be referenced during serial transfer by pointer control, and determines a next-access delay value during serial transfer by using the SPCMDm.SPNDEN bit and SPND, as listed in Table 25.11. For a definition of next-access delay, refer to section 25.3.5, Transfer Format.

Table 25.11 Relationship among SPNDEN Bit, SPND, and Next-Access Delay Value

| SPCMDm.SPNDEN Bit | SPND.SPNDL[2:0] Bits | Next-Access Delay Value |  |
|-------------------|----------------------|-------------------------|--|
| 0                 | 000b to 111b         | 1 RSPCK + 2 PCLK        |  |
| 1                 | 000b                 | 1 RSPCK + 2 PCLK        |  |
|                   | 001b                 | 2 RSPCK + 2 PCLK        |  |
|                   | 010b                 | 3 RSPCK + 2 PCLK        |  |
|                   | 011b                 | 4 RSPCK + 2 PCLK        |  |
|                   | 100b                 | 5 RSPCK + 2 PCLK        |  |
|                   | 101b                 | 6 RSPCK + 2 PCLK        |  |
|                   | 110b                 | 7 RSPCK + 2 PCLK        |  |
|                   | 111b                 | 8 RSPCK + 2 PCLK        |  |

#### (8) Initialization Flowchart

Figure 25.33 is a flowchart illustrating an example of initialization in SPI operation when the RSPI is used in master mode. For a description of how to set up the interrupt controller and I/O ports, refer to the descriptions given in the individual blocks.



Figure 25.33 Example of Initialization Flowchart in Master Mode (SPI Operation)

# (9) Software Processing Flow

Figure 25.34 to Figure 25.36 show examples of the flow of software processing.

#### (a) Transmit Processing Flow

When transmitting data, the CPU will be notified of the completion of data transmission by enabling the SPI interrupt after the last writing of data for transmission.

The completion of data transmission can also be checked by polling to see if the SPSR.IDLNF flag has become 0, instead of using the SPII interrupt. However, one cycle of PCLK is required for the time from when data for transmission is written in the SPDR register to when the IDLNF flag becomes 1. After the last data is written in the SPDR register, discard the value of the SPSR register once not to judge the condition with the IDLNF flag which has not yet become 1, and read and use the value of the SPSR.IDLNF flag to confirm the completion of data transmission.



Figure 25.34 Flowchart in Master Mode (Transmission)

# (b) Receive Processing Flow

The RSPI does not handle receive-only operation, so processing for transmission is required.



Figure 25.35 Flowchart in Master Mode (Reception)

#### (c) Flow of Error Processing

The RSPI has three types of error. When a mode fault error is generated, the SPCR.SPE bit is automatically cleared, stopping operations for transmission and reception. For errors from other sources, however, the SPCR.SPE bit is not cleared and operations for transmission and reception continue; accordingly, we recommend clearing of the SPCR.SPE bit to stop operations in the case of errors other than mode fault errors. Not doing so will lead to updating of the SPSSR.SPECM[2:0] bits.

When interrupts are used and an error occurs, if the ICU.IRn.IR flag for the SPTI or SPRI interrupt request is set to 1, clear the ICU.IRn.IR flag in the error processing routine. If the SPRI interrupt request is indicated, read the receive buffer and initialize the sequencer in the RSPI.



Figure 25.36 Flowchart for Master Mode (Error Processing)

### 25.3.10.2 Slave Mode Operation

### (1) Starting a Serial Transfer

If the SPCMD0.CPHA bit is 0, when detecting an SSLA0 input signal assertion, the RSPI needs to start driving valid data to the MISOA output signal. For this reason, when the CPHA bit is 0, the assertion of the SSLA0 input signal triggers the start of a serial transfer.

If the CPHA bit is 1, when detecting the first RSPCKA edge in an SSLA0 signal asserted condition, the RSPI needs to start driving valid data to the MISOA output signal. For this reason, when the CPHA bit is 1, the first RSPCKA edge in an SSLA0 signal asserted condition triggers the start of a serial transfer.

When detecting the start of a serial transfer in a condition in which the shift register is empty, the RSPI changes the status of the shift register to "full", so that data cannot be copied from the transmit buffer to the shift register when serial transfer is in progress. If the shift register was full before the serial transfer started, the RSPI leaves the status of the shift register unchanged, in the full state.

Irrespective of the CPHA bit setting, the timing at which the RSPI starts driving of the MISOA output signal is the SSLA0 signal assertion timing. The data which is output by the RSPI is either valid or invalid, depending on the CPHA bit setting.

For details on the RSPI transfer format, refer to section 25.3.5, Transfer Format. The polarity of the SSLA0 input signal depends on the setting of the SSLP.SSL0P bit.

### (2) Terminating a Serial Transfer

Irrespective of the SPCMD0.CPHA bit, the RSPI terminates the serial transfer after detecting an RSPCKA edge corresponding to the final sampling timing. When free space is available in the receive buffer (the SPRF flag is 0), upon termination of serial transfer the RSPI copies received data from the shift register to the receive buffer of the SPDR register. Upon termination of a serial transfer the RSPI changes the status of the shift register to "empty", regardless of the receive buffer state. A mode fault error occurs if the RSPI detects an SSLA0 input signal negation from the beginning of serial transfer to the end of serial transfer (refer to section 25.3.8, Error Detection).

The final sampling timing changes depending on the bit length of transfer data. In slave mode, the RSPI data length depends on the SPCMD0.SPB[3:0] bit setting. The polarity of the SSLA0 input signal depends on the SSLP.SSL0P bit setting.

For details on the RSPI transfer format, refer to section 25.3.5, Transfer Format.

### (3) Notes on Single-Slave Operations

If the SPCMD0.CPHA bit is 0, the RSPI starts serial transfers when it detects the assertion edge for an SSLA0 input signal. In the type of configuration shown in Figure 25.7 as an example, if the RSPI is used in single-slave mode, the SSLA0 signal is fixed at the active state. Therefore, when the CPHA bit is set to 0, the RSPI cannot correctly start a serial transfer. To correctly execute transmit/receive operations by the RSPI in slave mode in a configuration in which the SSLA0 input signal is fixed at the active state, the CPHA bit should be set to 1. If there is a need for setting the CPHA bit to 0, the SSLA0 input signal should not be fixed.

### (4) Burst Transfer

If the SPCMD0.CPHA bit is 1, continuous serial transfer (burst transfer) can be executed while retaining the assertion state for the SSLA0 input signal. If the CPHA bit is 1, the period from the first RSPCKA edge to the sampling timing for the reception of the final bit in an SSLA0 signal active state corresponds to a serial transfer period. Even when the SSLA0 input signal remains at the active level, the RSPI can accommodate burst transfers because it can detect the start of an access.

If the CPHA bit is 0, the second and subsequent serial transfers during burst transfer cannot be executed correctly.

### (5) Initialization Flowchart

Figure 25.37 is a flowchart illustrating an example of initialization in SPI operation when the RSPI is used in slave mode. For a description of how to set up the interrupt controller and I/O ports, refer to the descriptions given in the individual blocks.



Figure 25.37 Example of Initialization Flowchart in Slave Mode (SPI Operation)

### (6) Software Processing Flow

Figure 25.38 to Figure 25.40 show examples of the flow of software processing.

## (a) Transmit Processing Flow



Figure 25.38 Flowchart in Slave Mode (Transmission)

### (b) Receive Processing Flow

The RSPI does not handle receive-only operation, so processing for transmission is required.



Figure 25.39 Flowchart in Slave Mode (Reception)

### (c) Flow of Error Processing

In slave operation, even when a mode fault error is generated, the SPSR.MODF flag can be cleared regardless of the status of the SSLA0 pin.

When interrupts are used and an error occurs, if the ICU.IRn.IR flag for the SPTI or SPRI interrupt request is set to 1, clear the ICU.IRn.IR flag in the error processing routine. If the SPRI interrupt request is indicated, read the receive buffer and initialize the sequencer in the RSPI.



Figure 25.40 Flowchart for Slave Mode (Error Processing)

## 25.3.11 Clock Synchronous Operation

Setting the SPCR.SPMS bit to 1 selects clock synchronous operation of the RSPI. In clock synchronous operation, the SSLAi pin is not used, and the three pins of RSPCKA, MOSIA, and MISOA handle communications. The SSLAi pin is available as I/O port pins.

Although clock synchronous operation does not require use of the SSLAi pin, operation of the module is the same as in SPI operation. That is, in both master and slave operations, communications can be performed with the same flow as in SPI operation. However, mode fault errors are not detected because the SSLAi pin is not used.

Furthermore, operation should not be performed if clock synchronous operation proceeds when the SPCMDm.CPHA bit is set to 0 in slave mode (SPCR.MSTR = 0).

### 25.3.11.1 Master Mode Operation

## (1) Starting a Serial Transfer

The RSPI updates the data in the transmit buffer (SPTX) of SPDR when data is written to the SPDR register with the transmit buffer being empty (the SPTEF flag is 1 and data for the next transfer is not set). When the shift register is empty after the number of frames set in the SPDCR.SPFC[1:0] bits are written to the SPDR, the RSPI copies data from the transmit buffer to the shift register and starts serial transmission. Upon copying transmit data to the shift register, the RSPI changes the status of the shift register to "full", and upon termination of serial transfer, it changes the status of the shift register cannot be referenced.

For details on the RSPI transfer format, refer to section 25.3.5, Transfer Format.

However, transfer in clock synchronous operation is conducted without the SSLA0 output signal.

### (2) Terminating a Serial Transfer

The RSPI terminates the serial transfer after transmitting an RSPCKA edge corresponding to the sampling timing. If free space is available in the receive buffer (SPRX) (the SPRF flag is 0), upon termination of serial transfer, the RSPI copies data from the shift register to the receive buffer of the RSPI data register (SPDR).

It should be noted that the final sampling timing varies depending on the bit length of transfer data. In master mode, the RSPI data length depends on the SPCMDm.SPB[3:0] bit setting.

For details on the RSPI transfer format, refer to section 25.3.5, Transfer Format.

However, transfer in clock synchronous operation is conducted without the SSLA0 output signal.

### (3) Sequence Control

The transfer format employed in master mode is determined by SPSCR, SPCMDm, SPBR, SPCKD, SSLND, and SPND registers. Although the SSLAi signals are not output in clock synchronous operation, these settings are valid.

SPSCR is a register used to determine the sequence configuration for serial transfers that are executed by the RSPI in master mode. The following items are set in SPCMDm register: SSLAi output signal value, MSB/LSB first, data length, some of the bit rate settings, RSPCKA polarity/phase, whether SPCKD is to be referenced, whether SSLND is to be referenced, and whether SPND is to be referenced. SPBR holds some of the bit rate settings; SPCKD, an RSPI clock delay value; SSLND, an SSL negation delay; and SPND, a next-access delay value.

According to the sequence length that is assigned to SPSCR, the RSPI makes up a sequence comprised of a part or all of SPCMDm register. The RSPI contains a pointer to the SPCMDm register that makes up the sequence. The value of this pointer can be checked by reading the SPSSR.SPCP[2:0] bits. When the SPCR.SPE bit is set to 1 and the RSPI function is enabled, the RSPI loads the pointer to the commands in SPCMD0 register, and incorporates the SPCMD0 register setting into the transfer format at the beginning of serial transfer. The RSPI increments the pointer each time the next-access delay period for a data transfer ends. Upon completion of the serial transfer that corresponds to the final command comprising the sequence, the RSPI sets the pointer in SPCMD0 register, and in this manner the sequence is executed repeatedly.





Figure 25.41 Procedure for Determining the Form of Serial Transmission in Master Mode

In this section, a frame is the combination of the data (SPDR) and the settings (SPCMDm).



Figure 25.42 Concept of a Frame

Figure 25.43 shows the relationship between the command and the transmit and receive buffers in the sequence of operations specified by the settings in Table 25.4.



Figure 25.43 Correspondence between the RSPI Command Register and Transmit/Receive Buffers in Sequence Operations

## (4) Initialization Flowchart

Figure 25.44 is a flowchart illustrating an example of initialization in clock synchronous operation when the RSPI is used in master mode. For a description of how to set up the interrupt controller and I/O ports, refer to the descriptions given in the individual blocks.



Figure 25.44 Example of Initialization Flowchart in Master Mode (Clock Synchronous Operation)

# (5) Flow of Software Processing

Software processing during clock-synchronous master operation is the same as that for SPI master operation. For details, refer to section 25.3.10.1, (9) Software Processing Flow. Note that mode fault errors will not occur.

### 25.3.11.2 Slave Mode Operation

### (1) Starting a Serial Transfer

When the SPCR.SPMS bit is 1, the first RSPCKA edge triggers the start of a serial transfer in the RSPI.

When detecting the start of a serial transfer in a condition in which the shift register is empty, the RSPI changes the status of the shift register to "full", so that data cannot be copied from the transmit buffer to the shift register when serial transfer is in progress. If the shift register was full before the serial transfer started, the RSPI keeps the status of the shift register unchanged, in the full state.

When the SPMS bit is 1, the RSPI drives the MISOA output signal.

For details on the RSPI transfer format, refer to section 25.3.5, Transfer Format.

It should be noted that the SSLA0 input signal is not used in clock synchronous operation.

### (2) Terminating a Serial Transfer

The RSPI terminates the serial transfer after detecting an RSPCKA edge corresponding to the final sampling timing. When free space is available in the receive buffer (the SPRF flag is 0), upon termination of serial transfer the RSPI copies received data from the shift register to the receive buffer of the SPDR register. Upon termination of a serial transfer the RSPI changes the status of the shift register to "empty" regardless of the receive buffer status. The final sampling timing changes depending on the bit length of transfer data. In slave mode, the RSPI data length depends on the SPCMD0.SPB[3:0] bit setting.

For details on the RSPI transfer format, refer to section 25.3.5, Transfer Format.

### (3) Initialization Flowchart

Figure 25.45 is a flowchart illustrating an example of initialization in clock synchronous operation when the RSPI is used in slave mode. For a description of how to set up the interrupt controller and I/O ports, refer to the descriptions given in the individual blocks.



Figure 25.45 Example of Initialization Flowchart in Slave Mode (Clock Synchronous Operation)

# (4) Flow of Software Processing

Software processing during clock-synchronous slave operation is the same as that for SPI slave operation. For details, refer to section 25.3.10.2, (6) Software Processing Flow. Note that mode fault errors will not occur.

## 25.3.12 Loopback Mode

When 1 is written to the SPPCR.SPLP2 bit or SPPCR.SPLP bit, the RSPI shuts off the path between the MISOA pin and the shift register if the SPCR.MSTR bit is 1, and between the MOSIA pin and the shift register if the SPCR.MSTR bit is 0, and connects the input path and output path of the shift register. The RSPI does not shut off the path between the MOSIA pin and the shift register if the SPCR.MSTR bit is 1, and between the MISOA pin and the shift register if the SPCR.MSTR bit is 0. This is called loopback mode. When a serial transfer is executed in loopback mode, the transmit data for the RSPI or the reversed transmit data becomes the received data for the RSPI.

Table 25.12 lists the relationship among the SPLP2 and SPLP bits and the received data. Figure 25.46 shows the configuration of the shift register I/O paths for the case where the RSPI in master mode is set in loopback mode (SPPCR.SPLP2 = 0, SPPCR.SPLP = 1).

Table 25.12 SPLP2 and SPLP Bit Settings and Received Data

| SPPCR.SPLP2 Bit | SPPCR.SPLP Bit | Received Data                              |
|-----------------|----------------|--------------------------------------------|
| 0               | 0              | Input data from the MOSIA pin or MISOA pin |
| 0               | 1              | Inverted transmit data                     |
| 1               | 0              | Transmit data                              |
| 1               | 1              | Transmit data                              |



Figure 25.46 Configuration of Shift Register I/O Paths in Loopback Mode (Master Mode)

# 25.3.13 Self-Diagnosis of Parity Bit Function

The parity circuit consists of a parity bit adding unit used for transmit data and an error detecting unit used for received data. In order to detect defects in the parity bit adding unit and error detecting unit of the parity circuit, self-diagnosis is executed for the parity circuit following the flowchart shown in Figure 25.47.



Figure 25.47 Flowchart for Self-Diagnosis of Parity Circuit

## 25.3.14 Interrupt Sources

The RSPI has interrupt sources of receive buffer full, transmit buffer empty, mode fault, overrun, parity error, and RSPI idle. In addition, the DTC can be activated by the receive buffer full or transmit buffer empty interrupt to perform data transfer.

Since the vector address for SPEI is allocated to interrupt requests due to mode fault, overrun, and parity errors, the actual interrupt source must be determined from the flags. Interrupt sources for the RSPI are listed in Table 25.13. An interrupt is generated on satisfaction of an interrupt condition in Table 25.13. Clear the receive buffer full and transmit buffer empty sources through data transfer.

When using the DTC to perform data transmission/reception, the DTC must be set up first to be in a status in which transfer is enabled before making the RSPI settings. For the method for setting the DTC, refer to section 16, Data Transfer Controller (DTCa).

If the conditions for generating a transmit buffer empty or receive buffer full interrupt are generated while the ICU.IRn.IR flag is 1, the interrupt is not output as a request for ICU but is retained internally (the capacity for retention is one request per source). A retained interrupt request is output when the ICU.IRn.IR flag becomes 0. A retained interrupt request is automatically discarded once it is output as an actual interrupt request. The interrupt enable bit (the SPCR.SPTIE or SPCR.SPRIE bit) for an internally retained interrupt request can also be cleared to 0.

Table 25.13 Interrupt Sources of RSPI

| Interrupt Source                                   | Symbol | Interrupt Condition                                                                         | DTC Activation |
|----------------------------------------------------|--------|---------------------------------------------------------------------------------------------|----------------|
| Receive buffer full                                | SPRI   | The receive buffer becomes full (the SPRF flag becomes 1) while the SPCR.SPRIE bit is 1.    | Possible       |
| Transmit buffer empty                              | SPTI   | The transmit buffer becomes empty (the SPTEF flag becomes 1) while the SPCR.SPTIE bit is 1. | Possible       |
| RSPI errors (mode fault, overrun and parity error) | SPEI   | The SPSR.MODF, OVRF, or PERF flag is set to 1 while the SPCR.SPEIE bit is 1.                | Impossible     |
| RSPI idle                                          | SPII   | The SPSR.IDLNF flag is set to 0 while the SPCR2.SPIIE bit is 1.                             | Impossible     |

## 25.4 Usage Notes

## 25.4.1 Setting Module Stop Function

Module stop control register B (MSTPCRB) can be used to enable or disable the RSPI. Immediately after a reset, operation of the RSPI is disabled. Register access is enabled by releasing the module stop state. For details, refer to section 11, Low Power Consumption.

## 25.4.2 Note on Low Power Consumption Functions

When using the module stop function and entering a low power consumption mode other than sleep mode, set the SPCR.SPE bit to 0 before completing communication.

## 25.4.3 Notes on Starting Transfer

If the ICU.IRn.IR flag is 1 at the time transfer is to be started, an interrupt request is internally retained after transfer starts, and this can lead to unanticipated behavior of the ICU.IRn.IR flag.

When the ICU.IRn.IR flag is 1 at the time transfer is to start, follow the procedure below to clear interrupt requests before enabling operations (by setting the SPCR.SPE bit to 1).

- 1. Confirm that transfer has stopped (i.e. that the SPCR.SPE bit is 0).
- 2. Set the relevant interrupt enable bit (the SPCR.SPTIE or SPCR.SPRIE bit) to 0.
- 3. Read the relevant interrupt enable bit (the SPCR.SPTIE or SPCR.SPRIE bit) and confirm that its value is 0.
- 4. Set the ICU.IRn.IR flag to 0.

## 25.4.4 Notes on the SPRF and SPTEF flags

When polling the SPSR.SPRF flag and/or SPSR.SPTEF flag, set the SPCR.SPRIE bit and/or SPCR.SPTIE bit to 0.

# 26. CRC Calculator (CRC)

The CRC (Cyclic Redundancy Check) calculator generates CRC codes.

### 26.1 Overview

Table 26.1 lists the specifications of the CRC calculator, and Figure 26.1 shows a block diagram of the CRC calculator.

Table 26.1 CRC Specifications

| Item                           | Description                                                                                                                           |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Data for CRC calculation*1     | CRC codes are generated for any desired data in 8n-bit units (where n is a whole number)                                              |
| CRC processor unit             | 8-bit parallel processing                                                                                                             |
| CRC generating polynomial      | One of three generating polynomials is selectable  • 8-bit CRC  X8 + X2 + X + 1  • 16-bit CRC  X16 + X15 + X2 + 1  X16 + X12 + X5 + 1 |
| CRC calculation switching      | The bit order of CRC calculation results can be switched for LSB first or MSB first communication                                     |
| Low power consumption function | Module stop state can be set.                                                                                                         |

Note 1. The circuit does not have a function to divide data for calculation into CRC calculation units. Write data in 8-bit units.



Figure 26.1 CRC Block Diagram

# 26.2 Register Descriptions

# 26.2.1 CRC Control Register (CRCCR)

Address(es): 0008 8280h



| Bit      | Symbol   | Bit Name                            | Description                                                                                                                                                                                                                                                   | R/W   |
|----------|----------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| b1, b0   | GPS[1:0] | CRC Generating Polynomial Switching | b1 b0<br>0 0: No calculation is executed.<br>0 1: 8-bit CRC (X <sup>8</sup> + X <sup>2</sup> + X + 1)<br>1 0: 16-bit CRC (X <sup>16</sup> + X <sup>15</sup> + X <sup>2</sup> + 1)<br>1 1: 16-bit CRC (X <sup>16</sup> + X <sup>12</sup> + X <sup>5</sup> + 1) | R/W   |
| b2       | LMS      | CRC Calculation Switching           | Generates CRC for LSB first communication.     Generates CRC for MSB first communication.                                                                                                                                                                     | R/W   |
| b6 to b3 | _        | Reserved                            | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                        | R/W   |
| b7       | DORCLR   | CRCDOR Register Clear               | 1: Clears the CRCDOR register. This bit is read as 0.                                                                                                                                                                                                         | R/W*1 |

Note 1. Only 1 can be written.

### LMS Bit (CRC Calculation Switching)

This bit selects the bit order of generated 16-bit CRC code. Transmit the lower-order byte (b7 to b0) of the CRC code first for LSB first communication and the higher-order byte (b15 to b8) first for MSB first communication. For details on the transmission and reception of CRC codes, refer to section 26.3, Operation.

## **DORCLR Bit (CRCDOR Register Clear)**

Write 1 to this bit so that the CRCDOR register is set to 0000h.

This bit is read as 0. Only 1 can be written.

## 26.2.2 CRC Data Input Register (CRCDIR)

Address(es): 0008 8281h



CRCDIR is a readable and writable register. Write data for CRC calculation to this register.

# 26.2.3 CRC Data Output Register (CRCDOR)

Address(es): 0008 8282h



CRCDOR is a readable and writable register.

Since its initial value is 0000h, rewrite the CRCDOR register to perform calculation using a value other than the initial value.

Data written to the CRCDIR register is CRC calculated and the result is stored in the CRCDOR register. If the CRC code is calculated following the transferred data and the result is 0000h, there is no CRC error.

When an 8-bit CRC ( $X^8 + X^2 + X + 1$  polynomial) is in use, the valid CRC code is obtained in the low-order byte (b7 to b0). The high-order byte (b15 to b8) is not updated.

## 26.3 Operation

The CRC calculator generates CRC codes for use in LSB first or MSB first transfer.

The following shows examples of generating the CRC code for input data (F0h) using the 16-bit CRC generating polynomial ( $X^{16} + X^{12} + X^5 + 1$ ). In these examples, the value of the CRC data output register (CRCDOR) is cleared before CRC calculation.

When an 8-bit CRC (with the polynomial  $X^8 + X^2 + X + 1$ ) is in use, the valid bits of the CRC code are obtained in the lower-order byte of the CRCDOR register.



Figure 26.2 LSB First Data Transmission



Figure 26.3 MSB First Data Transmission



Figure 26.4 LSB First Data Reception



Figure 26.5 MSB First Data Reception

## 26.4 Usage Notes

# 26.4.1 Module Stop Function Setting

Operation of the CRC calculator can be disabled or enabled using the module stop control register B (MSTPCRB). After a reset, the CRC is in the module stop state. Register access is enabled by releasing the module stop state. For details, refer to section 11, Low Power Consumption.

### 26.4.2 Note on Transmission

Note that the sequence of transmission for the CRC code differs according to whether transmission is LSB first or MSB first.



Figure 26.6 LSB First and MSB First Data Transmission

# 27. 12-Bit A/D Converter (S12ADb)

In this section, "PCLK" is used to refer to PCLKB.

### 27.1 Overview

This MCU includes a 12-bit successive approximation A/D converter. Up to 14 channel analog inputs, temperature sensor outputs, or internal reference voltages can be selected.

The 12-bit A/D converter converts a maximum of 14 selected channels of analog inputs, temperature sensor outputs, or internal reference voltages into a 12-bit digital value through successive approximation.

The A/D converter has three operating modes: single scan mode in which the analog inputs of up to 14 arbitrarily selected channels are converted for only once in ascending channel order; and continuous scan mode in which the analog inputs of up to 14 arbitrarily selected channels are continuously converted in ascending channel order; and group scan mode in which up to 14 channels of the analog inputs are arbitrarily divided into two groups (group A and group B) and converted in ascending channel order in each group.

In group scan mode, the scan start conditions of group A and group B can be independently selected, thus allowing A/D conversion of group A and group B to be started independently.

In double trigger mode, one arbitrarily selected analog input channel is converted in single scan mode or group scan mode (group A), and the resulting data of A/D conversion started by the first and second triggers are stored into separate registers (duplication of A/D conversion data).

A/D conversion of the temperature sensor output or the internal reference voltage is accomplished independently. The VREFH0 or AVCC0 pin can be selected as the reference power supply pin for high-electric potential. The VREFL0 or AVSS0 pin can be selected as the reference power supply ground pin for low-electric potential.

Table 27.1 lists the specifications of the 12-bit A/D converter and Table 27.2 lists the functions of the 12-bit A/D converter. Figure 27.1 shows a block diagram of the 12-bit A/D converter.

Table 27.1 Specifications of 12-Bit A/D Converter (1/2)

| Item                   | Specifications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Number of units        | One unit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Input channels         | Up to 14 channels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Extended analog inputs | Temperature sensor output, internal reference voltage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| A/D conversion method  | Successive approximation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Resolution             | 12 bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Conversion time        | 1.0 µs per channel (when A/D conversion clock ADCLK = 32 MHz)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| A/D conversion clock   | Peripheral module clock PCLK*1 and A/D conversion clock ADCLK*1 can be set so that the frequency division ratio should be one of the following.  PCLK to ADCLK frequency division ratio = 1:1, 1:2, 1:4, 1:8, 2:1, 4:1  ADCLK is set using the clock generation circuit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Data registers         | For analog input: 14 data registers For duplication of A/D conversion data in double trigger mode: One data register For temperature sensor: One data register For internal reference voltage: One data register The A/D conversion result is stored in 12-bit A/D data registers. In addition mode, A/D conversion results are added and stored in A/D data registers as 14-bit data. Duplication of A/D conversion data  • A/D conversion data of one selected analog input channel is stored into A/D data register y when conversion is started by the first trigger and into the duplication register when started by the second trigger.  • Duplication is available only in double trigger mode in single scan mode or group scan mode. |

Table 27.1 Specifications of 12-Bit A/D Converter (2/2)

| Item                               | Specifications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operating modes                    | <ul> <li>Single scan mode: A/D conversion is performed for only once on the analog inputs of up to 14 arbitrarily selected channels. A/D conversion is performed only once on the temperature sensor output. A/D conversion is performed only once on the internal reference voltage.</li> <li>Continuous scan mode: A/D conversion is performed repeatedly on the analog inputs of up to 14 arbitrarily selected channels.*2</li> <li>Group scan mode: Up to 14 channels of analog inputs are divided into group A and group B and A/D conversion is performed only once on all the selected channels on a group basis. The scan start conditions of group A and group B can be independently selected, thus allowing A/D conversion of group A and group B to be started independently.</li> </ul>                                                                                                        |
| Conditions of A/D conversion start | <ul> <li>Software trigger</li> <li>Synchronous trigger Trigger by MTU</li> <li>Asynchronous trigger A/D conversion can be triggered from the ADTRG0# pin.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Functions                          | <ul> <li>Variable sampling state count</li> <li>A/D-converted value addition mode</li> <li>Double trigger mode (duplication of A/D conversion data)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Interrupt sources                  | <ul> <li>In the modes except double trigger mode and group scan mode, A/D scan end interrupt (S12ADI0) request can be generated on completion of single scan.</li> <li>In double trigger mode, A/D scan end interrupt (S12ADI0) request can be generated on completion of double scan.</li> <li>In group scan mode, A/D scan end interrupt (S12ADI0) request can be generated on completion of group A scan, whereas A/D scan end interrupt specially for group B (GBADI) request can be generated on completion of group B scan.</li> <li>In group scan mode with double trigger mode, A/D scan end interrupt (S12ADI0) request can be generated on completion of double scan of group A, whereas A/D scan end interrupt specially for group E (GBADI) request can be generated on completion of group B scan.</li> <li>S12ADI0 or GBADI interrupt can activate data transfer controller (DTC).</li> </ul> |
| Reference voltage                  | <ul> <li>VREFH0, AVCC0, or the internal reference voltage can be selected as the high-side reference voltage.</li> <li>VREFL0 or AVSS0 can be selected as the low-side reference voltage.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Low power consumption function     | Module stop state can be specified.*3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

- Note 1. Peripheral module clock PCLK is set according to the setting of the SCKCR.PCKB[3:0] bits and A/D conversion clock ADCLK is set according to the setting of the SCKCR.PCKB[3:0] bits.
- Note 2. Do not use continuous scan mode or group scan mode when temperature sensor output or internal reference voltage is selected.
- Note 3. When the module stop state is canceled, A/D conversion can be started after 1  $\mu s$  has elapsed.

Table 27.2 Functions of 12-Bit A/D Converter

| Item                            |                      | Function                                           |                                                                                              |  |
|---------------------------------|----------------------|----------------------------------------------------|----------------------------------------------------------------------------------------------|--|
| Analog input channels           |                      |                                                    | AN000 to AN004, AN006, AN008 to AN015, temperature sensor output, internal reference voltage |  |
| A/D conversion start conditions | Software             | Software trigger                                   | Enabled                                                                                      |  |
|                                 | Asynchronous trigger | ADTRG0#                                            | Enabled                                                                                      |  |
|                                 | Synchronous trigger  | TGRA compare match/input capture from MTU0         | TRG0AN                                                                                       |  |
|                                 |                      | TGRB compare match/input capture from MTU0         | TRG0BN                                                                                       |  |
|                                 |                      | TGRA compare match/input capture from MTU0 to MTU2 | TRGAN                                                                                        |  |
|                                 |                      | TRGE compare match from MTU0                       | TRG0EN                                                                                       |  |
|                                 |                      | TRGF compare match from MTU0                       | TRG0FN                                                                                       |  |
| Interrupt                       |                      |                                                    | S12ADI0 interrupt, GBADI interrupt                                                           |  |
| Module stop fund                | ction setting*1      |                                                    | MSTPCRA.MSTPA17 bit                                                                          |  |

Note 1. For details, refer to section 11, Low Power Consumption.



Figure 27.1 Block Diagram of 12-Bit A/D Converter

Table 27.3 lists the input pins of the 12-bit A/D converter.

Table 27.3 Input Pins of 12-Bit A/D Converter

| Pin Name                              | Input | Function                                               |
|---------------------------------------|-------|--------------------------------------------------------|
| AVCC0                                 | Input | Analog block power supply pin                          |
| AVSS0                                 | Input | Analog block ground pin                                |
| VREFH0                                | Input | Reference power supply pin                             |
| VREFL0                                | Input | Reference ground pin                                   |
| AN000 to AN004, AN006, AN008 to AN015 | Input | Analog input pins                                      |
| ADTRG0#                               | Input | External trigger input pin for starting A/D conversion |

# 27.2 Register Descriptions

# 27.2.1 A/D Data Registers y (ADDRy) (y = 0 to 4, 6, 8 to 15)

ADDRy are 16-bit read-only registers which store the A/D conversion results of channels AN000 to AN004, AN006, AN008 to AN015.

The A/D data registers use the following different formats depending on the setting of the A/D data register format select bit (ADRFMT) in ADCER or A/D-converted value addition mode.

### • ADCER.ADRFMT = 0 (Setting for right-alignment)

Address(es): ADDR0: 0008 9020h to ADDR4: 0008 9028h, ADDR6: 0008 902Ch, ADDR8: 0008 9030h to ADDR15: 0008 903Eh



| Bit        | Symbol   | Bit Name | Description                                            | R/W |
|------------|----------|----------|--------------------------------------------------------|-----|
| b11 to b0  | AD[11:0] | _        | 12-bit A/D-converted value                             | R   |
| b15 to b12 | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |

### ADCER.ADRFMT = 1 (Setting for left-alignment)

Address(es): ADDR0: 0008 9020h to ADDR4: 0008 9028h, ADDR6: 0008 902Ch, ADDR8: 0008 9030h to ADDR15: 0008 903Eh



| Bit       | Symbol   | Bit Name | Description                                            | R/W |
|-----------|----------|----------|--------------------------------------------------------|-----|
| b3 to b0  | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |
| b15 to b4 | AD[11:0] | _        | 12-bit A/D-converted value                             | R   |

### • When A/D-converted value addition mode is selected

Address(es): ADDR0: 0008 9020h to ADDR4: 0008 9028h, ADDR6: 0008 902Ch, ADDR8: 0008 9030h to ADDR15: 0008 903Eh



| Bit       | Symbol   | Bit Name | Description                                            | R/W |
|-----------|----------|----------|--------------------------------------------------------|-----|
| b1, b0    | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |
| b15 to b2 | AD[13:0] | _        | 14-bit A/D-converted value addition result             | R   |

When A/D-converted value addition mode is selected, the AD[13:0] bits in ADDRy show the value added by the A/D-converted value of the respective channels. In A/D-converted value addition mode, the setting of the ADRFMT bit in ADCER becomes invalid and the format of the register becomes left-aligned.

The following minimum and maximum values apply to channels on which A/D-converted value addition mode is selected.

First conversion:  $0000h \le ADDRy (y = 0 \text{ to } 4, 6, 8 \text{ to } 15) \le 3FFCh$ 

(ADDRy (y = 0 to 4, 6, 8 to 15): Bits 15 and 14 = 00b, bits 13 to 2 = AD11 to AD0, bits 1 and 0 = 00b)

Second conversion:  $0000h \le ADDRy (y = 0 \text{ to } 4, 6, 8 \text{ to } 15) \le 7FF8h$ 

(ADDRy (y = 0 to 4, 6, 8 to 15): Bit 15 = 0b, bits 14 to 2 = AD12 to AD0, bits 1 and 0 = 00b)

Third conversion:  $0000h \le ADDRy (y = 0 \text{ to } 4, 6, 8 \text{ to } 15) \le BFF4h$ 

(ADDRy (y = 0 to 4, 6, 8 to 15): Bits 15 to 2 = AD13 to AD0, bits 1 and 0 = 00b)

Fourth conversion:  $0000h \le ADDRy$  (y = 0 to 4, 6, 8 to 15)  $\le FFF0h$ 

(ADDRy (y = 0 to 4, 6, 8 to 15): Bits 15 to 2 = AD13 to AD0, bits 1 and 0 = 00b)

# 27.2.2 A/D Data Duplication Register (ADDBLDR)

ADDBLDR is a 16-bit read-only register used in double trigger mode. ADDBLDR holds the results of A/D conversion of the analog input of the channel selected for data duplication when the conversion is started by the second trigger. ADDBLDR uses the following different formats depending on the setting of the A/D data register format select bit (ADRFMT) in ADCER or A/D-converted value addition mode.

### • ADCER.ADRFMT = 0 (Setting for right-alignment)

Address(es): 0008 9018h



| Bit        | Symbol   | Bit Name | Description                                            | R/W |
|------------|----------|----------|--------------------------------------------------------|-----|
| b11 to b0  | AD[11:0] | _        | 12-bit A/D-converted value                             | R   |
| b15 to b12 | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |

### ADCER.ADRFMT = 1 (Setting for left-alignment)

Address(es): 0008 9018h



| Bit       | Symbol   | Bit Name | Description                                            | R/W |
|-----------|----------|----------|--------------------------------------------------------|-----|
| b3 to b0  | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |
| b15 to b4 | AD[11:0] | _        | 12-bit A/D-converted value                             | R   |

#### When A/D-converted value addition mode is selected

Address(es): 0008 9018h



| Bit       | Symbol   | Bit Name | Description                                            | R/W |
|-----------|----------|----------|--------------------------------------------------------|-----|
| b1, b0    | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |
| b15 to b2 | AD[13:0] | _        | 14-bit A/D-converted value addition result             | R   |

When A/D-converted value addition mode is selected, the ADDBLDR.AD[13:0] bits show the value added by the A/D-converted value of the respective channels. In A/D-converted value addition mode, the setting of the ADCER.ADRFMT bit becomes invalid and the format of the register becomes left-aligned.



# 27.2.3 A/D Temperature Sensor Data Register (ADTSDR)

ADTSDR is a 16-bit read-only register that holds the A/D conversion results of the temperature sensor output. The following different formats are used depending on the settings of the A/D data register format select bit (ADCER.ADRFMT) and A/D-converted value addition mode.

## ADCER.ADRFMT = 0 (Setting for right-alignment)

Address(es): 0008 901Ah



| Bit        | Symbol   | Bit Name | Description                                            | R/W |
|------------|----------|----------|--------------------------------------------------------|-----|
| b11 to b0  | AD[11:0] | _        | 12-bit A/D-converted value                             | R   |
| b15 to b12 | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |

### • ADCER.ADRFMT = 1 (Setting for left-alignment)

Address(es): 0008 901Ah



| Bit       | Symbol   | Bit Name | Description                                            | R/W |
|-----------|----------|----------|--------------------------------------------------------|-----|
| b3 to b0  | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |
| b15 to b4 | AD[11:0] | _        | 12-bit A/D-converted value                             | R   |

### When A/D-converted value addition function is selected

Address(es): 0008 901Ah



| Bit       | Symbol   | Bit Name | Description                                                      | R/W |
|-----------|----------|----------|------------------------------------------------------------------|-----|
| b1, b0    | _        | Reserved | These bits are read as 0. The write value should be 0.           | R/W |
| b15 to b2 | AD[13:0] | _        | A/D-converted value addition result of temperature sensor output | R   |

When A/D-converted value addition mode is selected, the ADDBLDR.AD[13:0] bits show the temperature sensor output value added by the A/D-converted value. In A/D-converted value addition mode, the setting of the ADCER.ADRFMT bit becomes invalid and the format of the register becomes left-aligned.

# 27.2.4 A/D Internal Reference Voltage Data Register (ADOCDR)

ADOCDR is a 16-bit read-only register that holds the A/D conversion results of the internal reference voltage. The following different formats are used depending on the setting of the A/D data register format select bit (ADRFMT) in ADCER or A/D-converted value addition mode.

## • ADCER.ADRFMT = 0 (Setting for right-alignment)

Address(es): 0008 901Ch



| Bit        | Symbol   | Bit Name | Description                                            | R/W |
|------------|----------|----------|--------------------------------------------------------|-----|
| b11 to b0  | AD[11:0] | _        | 12-bit A/D-converted value                             | R   |
| b15 to b12 | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |

### ADCER.ADRFMT = 1 (Setting for left-alignment)

Address(es): 0008 901Ch



| Bit       | Symbol   | Bit Name | Description                                            | R/W |
|-----------|----------|----------|--------------------------------------------------------|-----|
| b3 to b0  | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |
| b15 to b4 | AD[11:0] | _        | 12-bit A/D-converted value                             | R   |

### • When A/D-converted value addition mode is selected

Address(es): 0008 901Ch



| Bit       | Symbol   | Bit Name | Description                                            | R/W |
|-----------|----------|----------|--------------------------------------------------------|-----|
| b1, b0    | _        | Reserved | These bits are read as 0. The write value should be 0. | R/W |
| b15 to b2 | AD[13:0] | _        | 14-bit A/D-converted value addition result             | R   |

When A/D-converted value addition mode is selected, the AD[13:0] bits in ADOCDR show the value added by the A/D-converted value of the internal reference voltage. In A/D-converted value addition mode, the setting of the ADRFMT bit in ADCER becomes invalid and the format of the register becomes left-aligned.

# 27.2.5 A/D Control Register (ADCSR)

Address(es): 0008 9000h



| Bit      | Symbol      | Bit Name                                             | Description                                                                                                                                                            | R/W |
|----------|-------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | DBLANS[4:0] | A/D Conversion Data<br>Duplication Channel<br>Select | Select one of 14 analog input channels for A/D conversion data duplication. These bits are valid only in double trigger mode.                                          | R/W |
| b5       | _           | Reserved                                             | This bit is read as 0. The write value should be 0.                                                                                                                    | R/W |
| b6       | GBADIE      | Group B Scan End<br>Interrupt Enable                 | Disables GBADI interrupt generation upon group B scan completion.     Enables GBADI interrupt generation upon group B scan completion.                                 | R/W |
| b7       | DBLE        | Double Trigger Mode<br>Select                        | Deselects double trigger mode.     Selects double trigger mode.                                                                                                        | R/W |
| b8       | EXTRG       | Trigger Select*1                                     | O: A/D conversion is started by the synchronous trigger (MTU).     1: A/D conversion is started by the asynchronous trigger (ADTRG0#).                                 | R/W |
| b9       | TRGE        | Trigger Start Enable                                 | Disables A/D conversion to be started by the synchronous or asynchronous trigger.     Enables A/D conversion to be started by the synchronous or asynchronous trigger. | R/W |
| b10      | ADHSC       | A/D Conversion Mode<br>Select                        | 0: Normal conversion 1: High-speed conversion                                                                                                                          | R/W |
| b11      | _           | Reserved                                             | This bit is read as 0. The write value should be 0.                                                                                                                    | R/W |
| b12      | ADIE        | Scan End Interrupt<br>Enable                         | Disables S12ADI0 interrupt generation upon scan completion.     Enables S12ADI0 interrupt generation upon scan completion.                                             | R/W |
| b14, b13 | ADCS[1:0]   | Scan Mode Select                                     | b14 b13 0 0: Single scan mode 0 1: Group scan mode 1 0: Continuous scan mode 1 1: Setting prohibited                                                                   | R/W |
| b15      | ADST        | A/D Conversion Start                                 | 0: Stops A/D conversion. 1: Starts A/D conversion.                                                                                                                     | R/W |

Note 1. Starting A/D conversion using an external pin (asynchronous trigger)

If 1 is written to both the TRGE and EXTRG bits in ADCSR when a high-level signal is input to the external pin (ADTRG0#), and then if the ADTRG0# signal is driven low, the falling edge of ADTRG0# is detected and the scan conversion process is started. In this case, the pulse width of the low-level input must be at least 1.5 PCLK clock cycles.

## DBLANS[4:0] Bits (A/D Conversion Data Duplication Channel Select)

The DBLANS[4:0] bits select one of the channels for A/D conversion data duplication in double trigger mode. The A/D conversion results of the analog input of the selected channel are stored into A/D data register y when conversion is started by the first trigger, and into the A/D data duplication register when started by the second trigger. Table 27.4 shows the relationship between the DBLANS[4:0] bit settings and selected duplication channel. A/D-converted value addition mode with double trigger mode can be set by selecting the channel selected by the DBLANS[4:0] bits using the ADADS register. If double trigger mode is selected, the channel selected by the ADANSA register is invalid, and the channel selected by the DBLANS[4:0] bits is subjected to A/D conversion instead. When converting analog inputs of channels, temperature sensor output and internal reference voltage should not be selected for A/D conversion.

The DBLANS[4:0] bits should be set while the ADST bit is 0 (they should not be set simultaneously when 1 is written to the ADST bit.)

01000

DBLANS[4:0] **Duplication Channel** DBLANS[4:0] **Duplication Channel** 00000 AN000 01001 AN009 00001 AN001 01010 AN010 00010 AN002 01011 AN011 00011 AN012 AN003 01100 00100 AN004 01101 AN013 00110 AN006 01110 AN014

Table 27.4 Relationship between DBLANS[4:0] Bit Settings and Double Trigger Enabled Channels

01111

## **GBADIE Bit (Group B Scan End Interrupt Enable)**

AN008

The GBADIE bit enables or disables group B scan end interrupt (GBADI) in group scan mode.

### **DBLE Bit (Double Trigger Mode Select)**

In double trigger mode, the following operation is performed after scanning is started by the MTU trigger selected by the ADSTRGR.TRSA[3:0] bits.

AN015

- 1. When the ADIE bit is 1, a scan end interrupt is not output upon first scan completion but is output upon second scan completion.
- 2. The A/D conversion results of the analog input of the channel selected by the DBLANS[4:0] bits are stored into A/D data register y for the first time, and into the A/D data duplication register for the second time.

Setting the DBLE bit to 1 invalidates the channel selected by the ADANSA register. In continuous scan mode, double trigger mode should not be selected. Temperature sensor output and internal reference voltage should not be selected for A/D conversion. In double trigger mode, software trigger should not be selected. The DBLE bit should be set while ADST bit is 0 (it should not be set simultaneously when 1 is written to the ADST bit.)

### **TRGE Bit (Trigger Start Enable)**

The TRGE bit enables or disables A/D conversion by the synchronous trigger and the asynchronous trigger. This bit should be set to 1 in group scan mode.

### ADHSC Bit (A/D Conversion Mode Select)

This bit selects whether A/D conversion mode is normal conversion mode or high-speed conversion mode.

Normal conversion mode can be selected when AVCC0 is in the range of 1.8 V to 3.6 V.

High-speed conversion mode can be selected when AVCC0  $\geq$  2.4 V.

Conversion can be performed in 1  $\mu$ s if the ADCLK clock is 32 MHz when AVCC0  $\geq$  2.7 V and high-speed conversion mode is selected.

### **ADIE Bit (Scan End Interrupt Enable)**

The ADIE bit enables or disables the A/D scan end interrupt (S12ADI0) in scans except for group B scan in group scan mode.

With double trigger mode deselected, the S12ADI0 interrupt is generated when the first scan is completed if the ADIE bit is set to 1.

With temperature sensor output or internal reference voltage being selected, the S12ADI0 interrupt is also generated when A/D conversion is completed if the ADIE bit is set to 1.

With double trigger mode selected, the S12ADI0 interrupt is generated when the second scan is completed if the ADIE bit is set to 1 as long as the scan is started by the MTU trigger selected by the ADSTRGR.TRSA[3:0] bits.

When scanning is started by a software trigger, even with double trigger mode selected, the S12ADI0 interrupt is generated when scanning is completed if the ADIE bit is set to 1.



### ADCS[1:0] Bits (Scan Mode Select)

The ADCS[1:0] bits select the scan mode.

In single scan mode, A/D conversion is performed for the analog inputs of a maximum of 14 channels selected with the ADANSA register in the ascending order of the channel number, and when one cycle of A/D conversion is completed for all the selected channels, scan conversion is stopped.

In continuous scan mode, while the ADCSR.ADST bit is 1, A/D conversion is performed for the analog inputs of a maximum of 14 channels selected with the ADANSA register in the ascending order of the channel number, and when one cycle of A/D conversion is completed for all the selected channels, A/D conversion is repeated beginning at the first channel. A/D conversion is repeated until the ADCSR.ADST bit is set to 0.

In group scan mode, A/D conversion is performed for the analog inputs (group A) of a maximum of 14 channels selected with the ADANSA register in the ascending order of the channel number after scanning is started by the MTU trigger selected by the ADSTRGR.TRSA[3:0] bits, and when one cycle of A/D conversion is completed for all the selected channels, A/D conversion is stopped. A/D conversion is also performed for the analog inputs (group B) of a maximum of 14 channels selected with the ADANSB register in the ascending order of the channel number after scanning is started by the MTU trigger selected by the ADSTRGR.TRSA[3:0] bits, and when one cycle of A/D conversion is completed for all the selected channels, A/D conversion is stopped. In group scan mode, different channels and triggers should be selected for group A and group B.

When temperature sensor output or internal reference voltage is selected, single scan mode should be selected and all the channels selected by the ADANSA register should be deselected, after which A/D conversion is to be started. A/D conversion stops after completion of A/D conversion of the temperature sensor output or the internal reference voltage selected.

The ADCS[1:0] bits should be set while the ADST bit is 0 (it should not be set simultaneously when 1 is written to the ADST bit.)

### **ADST Bit (A/D Conversion Start)**

The ADST bit starts or stops A/D conversion process.

Before the ADST bit is set to 1, set the A/D conversion clock, the conversion mode, and conversion target analog input. [Setting conditions]

- 1 is written by software.
- The synchronous trigger (MTU) selected by the ADSTRGR.TRSA[3:0] bits is detected with ADCSR.EXTRG and ADCSR.TRGE bits being set to 0 and 1, respectively.
- A synchronous trigger (MTU) selected by the ADSTRGR.TRSB[3:0] bits is detected with the ADCSR.TRGE bit being set to 1 in group scan mode.
- The asynchronous trigger is detected with the ADCSR.TRGE and ADCSR.EXTRG bits being set to 1 and the ADSTRGR.TRSA[3:0] bits being set to 0000b.

### [Clearing conditions]

- 0 is written by software.
- The A/D conversion of all the channels selected is completed in single scan mode.
- The A/D conversion of the temperature sensor output or the internal reference voltage selected is completed in single scan mode.
- Group A scan is completed in group scan mode.
- Group B scan is completed in group scan mode.



# 27.2.6 A/D Channel Select Register A (ADANSA)

Address(es): 0008 9004h



| Bit       | Symbol     | Bit Name                              | Description                                                                                            | R/W |
|-----------|------------|---------------------------------------|--------------------------------------------------------------------------------------------------------|-----|
| b4 to b0  | ANSA[4:0]  | A/D Conversion Channel 0 to 4 Select  | AN000 to AN004 are not subjected to conversion.     AN000 to AN004 are subjected to scan conversion.   | R/W |
| b5        | _          | Reserved                              | This bit is read as 0. The write value should be 0.                                                    | R/W |
| b6        | ANSA[6]    | A/D Conversion Channel 6 Select       | O: AN006 is not subjected to conversion.     1: AN006 is subjected to scan conversion.                 | R/W |
| b7        | _          | Reserved                              | This bit is read as 0. The write value should be 0.                                                    | R/W |
| b15 to b8 | ANSA[15:8] | A/D Conversion Channel 8 to 15 Select | 0: AN008 to AN015 are not subjected to conversion. 1: AN008 to AN015 are subjected to scan conversion. | R/W |

The ADANSA register selects analog input channels for A/D conversion from among AN000 to AN004, AN006, AN008 to AN015. In group scan mode, group A channels are to be selected.

### ANSA[15:8, 6, 4:0] Bits (A/D Conversion Channels 0 to 4, 6, 8 to 15 Select)

The ANSA[15:8, 6, 4:0] bits select analog input channels for A/D conversion from among AN000 to AN004, AN006, AN008 to AN015. The channels to be selected and the number of channels can be arbitrarily set. The ANSA[0] bit corresponds to AN000 and the ANSA[15] bit corresponds to AN015. When A/D conversion of analog inputs of the channels is to be performed, A/D conversion of the temperature sensor output and the internal reference voltage should not be performed.

When double trigger mode is selected, the channel selected by the ANSA[15:8, 6, 4:0] bits is invalid, and the channel selected by the ADCSR.DBLANS[4:0] bits is selected in group A instead.

The ANSA[15:8, 6, 4:0] bits should be set while the ADCSR.ADST bit is 0.

# 27.2.7 A/D Channel Select Register B (ADANSB)

Address(es): 0008 9014h



| Bit       | Symbol     | Bit Name                               | Description                                                                                                | R/W |
|-----------|------------|----------------------------------------|------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0  | ANSB[4:0]  | A/D Conversion Channels 0 to 4 Select  | 0: AN000 to AN004 are not subjected to conversion. 1: AN000 to AN004 are subjected to scan conversion.     | R/W |
| b5        | _          | Reserved                               | This bit is read as 0. The write value should be 0.                                                        | R/W |
| b6        | ANSB[6]    | A/D Conversion Channel 6 Select        | O: AN006 is not subjected to conversion.     1: AN006 is subjected to scan conversion.                     | R/W |
| b7        | _          | Reserved                               | This bit is read as 0. The write value should be 0.                                                        | R/W |
| b15 to b8 | ANSB[15:8] | A/D Conversion Channels 8 to 15 Select | O: AN008 to AN015 are not subjected to conversion.     1: AN008 to AN015 are subjected to scan conversion. | R/W |

The ADANSB register selects analog inputs 0 to 4, 6, and 8 to 15 of the channels for A/D conversion in group B in group scan mode. The ADANSB register is not used in any other scan mode.

### ANSB[15:8, 6, 4:0] Bits (A/D Conversion Channels 0 to 4, 6, 8 to 15 Select)

The ADANSB register selects channels for A/D conversion in group B from among AN000 to AN004, AN006, AN008 to AN015 in group scan mode. ADANSB is not used in any other scan mode. The channels for conversion can be selected from among the channels other than group A channels, which are selected by the ADANSA register or ADCSR.DBLANS[4:0] bits in double trigger mode. The ANSB[0] bit corresponds to AN000 and the ANSB[15] bit corresponds to AN015. When A/D conversion of analog inputs of the channels is to be performed, A/D conversion of the temperature sensor output and the internal reference voltage should not be performed.

The ANSB[15:8, 6, 4:0] bits should be set while the ADST bit is 0.

## 27.2.8 A/D-Converted Value Addition Mode Select Register (ADADS)

Address(es): 0008 9008h



| Bit       | Symbol    | Bit Name                                                   | Description                                                                                                                                              | R/W |
|-----------|-----------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0  | ADS[4:0]  | A/D-Converted Value<br>Addition Channels 0 to 4<br>Select  | O: A/D-converted value addition function for AN000 to AN004 are not selected.  1: A/D-converted value addition function for AN000 to AN004 are selected. | R/W |
| b5        | _         | Reserved                                                   | This bit is read as 0. The write value should be 0.                                                                                                      | R/W |
| b6        | ADS[6]    | A/D-Converted Value<br>Addition Channel 6 Select           | A/D-converted value addition function for AN006 is not selected.     A/D-converted value addition function for AN006 is selected.                        | R/W |
| b7        | _         | Reserved                                                   | This bit is read as 0. The write value should be 0.                                                                                                      | R/W |
| b15 to b8 | ADS[15:8] | A/D-Converted Value<br>Addition Channels 15 to 8<br>Select | O: A/D-converted value addition function for AN015 to AN008 are not selected.  1: A/D-converted value addition function for AN015 to AN008 are selected. | R/W |

The ADADS register selects the channels 0 to 4, 6, 8 to 15 on which A/D conversion is performed successively two to four times and then converted values are added (integrated).

### ADS[15:8, 6, 4:0] Bits (A/D-Converted Value Addition Channels 0 to 4, 6, 8 to 15 Select)

When the ADS[15:8, 6, 4:0] bits of the number that is the same as that of A/D converted channel selected by the ADANSA.ANSA[15:8, 6, 4:0] bits or ADCSR.DBLANS[4:0] bits and ADANSB.ANSB[15:8, 6, 4:0] bits is set to 1, these bits perform A/D conversion of analog input of the selected channels successively two to four times that is set with the ADADC.ADC[1:0] bits and returns the added (integrated) conversion results to the A/D data register. For the channel for which the A/D conversion is performed and addition mode is not selected, a normal one-time conversion is performed and the conversion result is returned to the A/D data register.

The ADS[15:8, 6, 4:0] bits should be set while the ADCSR.ADST bit is 0.

Figure 27.2 shows a scanning operation sequence in which both the ADS[2] and ADS[4] bits are set to 1. In continuous scan mode (ADCSR.ADCS[1:0] = 10b), it is assumed that the addition count is set to 3 (ADADC.ADC[1:0] = 11b) and the channels AN000 to AN004, AN006 are selected (ADANSA.ANSA[15:0] = 005Fh). The conversion process begins with AN000. The AN002 conversion is performed successively 4 times, and the added (integrated) value is returned to A/D data register 2. After that the AN003 conversion process is started. The AN004 conversion is performed successively 4 times and the added (integrated) value is returned to A/D data register 4. After conversion of AN006, the conversion operation is once again performed in the same sequence from AN000. For the channel for which the addition mode is not selected, the A/D data register format is determined by the ADCER.ADRFMT bit (right-alignment or left-alignment).



Figure 27.2 Scan Conversion Sequence with ADADC.ADC[1:0] = 11b, ADS[2] = 1, and ADS[4] = 1

### 27.2.9 A/D-Converted Value Addition Count Select Register (ADADC)

Address(es): 0008 900Ch



| Bit      | Symbol   | Bit Name              | Description                                                                                                                                                                                        | R/W |
|----------|----------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1, b0   | ADC[1:0] | Addition Count Select | b1 b0 0 0: 1-time conversion (no addition; same as normal conversion) 0 1: 2-time conversion (addition once) 1 0: 3-time conversion (addition twice) 1 1: 4-time conversion (addition three times) | R/W |
| b7 to b2 | _        | Reserved              | These bits are read as 0. The write value should be 0.                                                                                                                                             | R/W |

The ADADC register sets the addition count for the channels for which A/D-converted value addition mode is selected, and for A/D conversion of the temperature sensor output and the internal reference voltage.

#### ADC[1:0] Bits (Addition Count Select)

These bits set the addition count common to the channels for which A/D conversion or A/D-converted value addition mode is selected, including the channels selected in double trigger mode (by the ADCSR.DBLANS[4:0] bits), and to A/D conversion of the temperature sensor output and the internal reference voltage.

The ADC[1:0] bits should be set while the ADCSR.ADST bit is 0.



### 27.2.10 A/D Control Extended Register (ADCER)

Address(es): 0008 900Eh



| Bit       | Symbol | Bit Name                        | Description                                                                                                                       | R/W |
|-----------|--------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0  | _      | Reserved                        | These bits are read as 0. The write value should be 0.                                                                            | R/W |
| b5        | ACE    | Automatic Clearing Enable       | Disables automatic clearing.     Enables automatic clearing.                                                                      | R/W |
| b14 to b6 | _      | Reserved                        | These bits are read as 0. The write value should be 0.                                                                            | R/W |
| b15       | ADRFMT | A/D Data Register Format Select | O: Right-alignment is selected for the A/D data register format.  1: Left-alignment is selected for the A/D data register format. | R/W |

#### **ACE Bit (Automatic Clearing Enable)**

The ACE bit enables or disables automatic clearing (All 0) of ADDRy, ADOCDR, ADDBLDR, and ADTSDR after the register has been read by the CPU or DTC. This function enables update failures of the ADDRy, ADOCDR, ADDBLDR, and ADTSDR registers to be detected.

#### ADRFMT Bit (A/D Data Register Format Select)

The ADRFMT bit specifies left-alignment or right-alignment for the data to be stored in ADDRy, ADOCDR, ADDBLDR, and ADTSDR.

When the A/D-converted value addition mode is selected, the format of each data register is fixed to left-alignment, irrespective of the ADCER.ADRFMT bit value.

For details on the format of the data registers, refer to section 27.2.1, A/D Data Registers y (ADDRy) (y = 0 to 4, 6, 8 to 15), section 27.2.2, A/D Data Duplication Register (ADDBLDR), section 27.2.3, A/D Temperature Sensor Data Register (ADTSDR), and section 27.2.4, A/D Internal Reference Voltage Data Register (ADOCDR).

### 27.2.11 A/D Start Trigger Select Register (ADSTRGR)

Address(es): 0008 9010h



| Bit        | Symbol    | Bit Name                                        | Description                                                                                                                                                    | R/W |
|------------|-----------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0   | TRSB[3:0] | A/D Conversion Start Trigger Select for Group B | Select the A/D conversion start trigger for group B in group scan mode.                                                                                        | R/W |
| b7 to b4   | _         | Reserved                                        | These bits are read as 0. The write value should be 0.                                                                                                         | R/W |
| b11 to b8  | TRSA[3:0] | A/D Conversion Start Trigger Select             | Select the A/D conversion start trigger in single scan mode and continuous mode. In group scan mode, the A/D conversion start trigger for group A is selected. | R/W |
| b15 to b12 | _         | Reserved                                        | These bits are read as 0. The write value should be 0.                                                                                                         | R/W |

#### TRSB[3:0] Bits (A/D Conversion Start Trigger Select for Group B)

The TRSB[3:0] bits select the trigger to start scanning of the analog input selected in group B. The TRSB[3:0] bits require to be set only in group scan mode and are not used in any other scan mode. For the scan conversion start trigger for group B, setting software trigger or asynchronous trigger is prohibited. Therefore, the TRSB[3:0] bits should be set to the value other than 0000b and the ADCSR.TRGE bit should be set to 1 in group scan mode.

Table 27.5 lists the A/D conversion startup sources selected by the TRSB[3:0] bits.

### TRSA[3:0] Bits (A/D Conversion Start Trigger Select)

The TRSA[3:0] bits select the trigger to start A/D conversion in single scan mode and continuous scan mode. In group scan mode, the trigger to start scanning of the analog input selected in group A is selected. For scan execution in group scan mode or double trigger mode, software trigger or asynchronous trigger cannot be used.

- When using the A/D conversion startup source of the synchronous trigger (MTU), set the ADCSR.TRGE bit to 1 and set the ADCSR.EXTRG bit to 0.
- When using the asynchronous trigger (ADTRG0#), set the ADCSR.TRGE bit to 1 and set the ADCSR.EXTRG bit to 1.
- Software trigger (ADCSR.ADST) is enabled regardless of the set values of the ADCSR.TRGE and ADCSR.EXTRG bits and the TRSA[3:0] bits.

Table 27.6 lists the A/D conversion startup sources selected by the TRSA[3:0] bits.

Table 27.5 List of A/D Conversion Startup Sources Selected by TRSB[3:0] Bits

| Module | Source | Remarks                                            | TRSB[3] | TRSB[2] | TRSB[1] | TRSB[0] |
|--------|--------|----------------------------------------------------|---------|---------|---------|---------|
| MTU    | TRG0AN | TGRA input capture/compare match from MTU0         | 0       | 0       | 0       | 1       |
|        | TRG0BN | TGRB input capture/compare match B from MTU0       | 0       | 0       | 1       | 0       |
|        | TRGAN  | TGRA input capture/compare match from MTU0 to MTU2 | 0       | 0       | 1       | 1       |
|        | TRG0EN | TGRE compare match from MTU0                       | 0       | 1       | 0       | 0       |
|        | TRG0FN | TGRF compare match from MTU0                       | 0       | 1       | 0       | 1       |

Table 27.6 List of A/D Conversion Startup Sources Selected by TRSA[3:0] Bits

| Module         | Source  | Remarks                                            | TRSA[3] | TRSA[2] | TRSA[1] | TRSA[0] |
|----------------|---------|----------------------------------------------------|---------|---------|---------|---------|
| ADC            | ADST    | Software trigger                                   | _       | _       | _       | _       |
| External input | ADTRG0# | A/D conversion start trigger pin                   | 0       | 0       | 0       | 0       |
| MTU            | TRG0AN  | TGRA input capture/compare match from MTU0         | 0       | 0       | 0       | 1       |
|                | TRG0BN  | TGRB input capture/compare match B from MTU0       | 0       | 0       | 1       | 0       |
|                | TRGAN   | TGRA input capture/compare match from MTU0 to MTU2 | 0       | 0       | 1       | 1       |
|                | TRG0EN  | TGRE compare match from MTU0                       | 0       | 1       | 0       | 0       |
|                | TRG0FN  | TGRF compare match from MTU0                       | 0       | 1       | 0       | 1       |

### 27.2.12 A/D Converted Extended Input Control Register (ADEXICR)

Address(es): 0008 9012h



| Bit        | Symbol                                                                                                                                                    | Bit Name                                                                     | Description                                                                                                                                                       | R/W |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0         | TSSAD                                                                                                                                                     | Temperature Sensor Output<br>A/D-Converted Value Addition<br>Function Select | Temperature sensor output A/D-converted value addition function is not selected.     Temperature sensor output A/D-converted value addition function is selected. | R/W |
| b1         | OCSAD                                                                                                                                                     | Internal Reference Voltage<br>A/D-Converted Value Addition<br>Mode Select    | O: Internal reference voltage A/D-converted value addition mode is not selected     I: Internal reference voltage A/D-converted value addition mode is selected   | R/W |
| b7 to b2   | _                                                                                                                                                         | Reserved                                                                     | These bits are read as 0. The write value should be 0.                                                                                                            | R/W |
| b8         | TSS Temperature Sensor Output 0: A/D conversion of temperature sensor output is not performed 1: A/D conversion of temperature sensor output is performed |                                                                              | R/W                                                                                                                                                               |     |
| b9         | ocs                                                                                                                                                       | Internal Reference Voltage<br>A/D Conversion Select                          | A/D conversion of internal reference voltage is not performed     A/D conversion of internal reference voltage is performed                                       | R/W |
| b15 to b10 | _                                                                                                                                                         | Reserved                                                                     | These bits are read as 0. The write value should be 0.                                                                                                            | R/W |

#### TSSAD Bit (Temperature Sensor Output A/D-Converted Value Addition Function Select)

When the TSSAD bit is set to 1, A/D conversion of temperature sensor output is selected and performed successively 2 to 4 times that is set with the ADADC.ADC[1:0] bits, and the added value is returned to the A/D temperature sensor data register (ADTSDR). The TSSAD bit should be set while the ADCSR.ADST bit is 0.

#### OCSAD Bit (Internal Reference Voltage A/D-Converted Value Addition Mode Select)

The OCSAD bit selects A/D conversion for the internal reference voltage. Setting the OCSAD bit to 1 performs A/D conversion of the internal reference voltage successively two to four times that is set with the ADADC.ADC[1:0] bits and returns the integrated value to the A/D internal reference voltage data register (ADOCDR). The OCSAD bit should be set while the ADCSR.ADST bit is 0.

#### TSS Bit (Temperature Sensor Output A/D Conversion Select)

The TSS bit selects A/D conversion for the temperature sensor output. When A/D conversion of the temperature sensor output is to be performed, all the bits in registers ADANSA and ADANSB, the ADCSR.DBLE bit, and the OCS bit should be set to 0 in single scan mode. The TSS bit should be set while the ADST bit is 0. When comparator B (CMPB) is set to use the internal reference voltage, the temperature sensor output is not selected even by setting the TSS bit to 1. Do not use the first conversion result after the TSS bit is set to 1. Insert a stabilization wait time of 5 µs after the first conversion is completed and before the second conversion is started.

#### OCS Bit (Internal Reference Voltage A/D Conversion Select)

The OCS bit selects A/D conversion for the internal reference voltage. When A/D conversion of the internal reference voltage is to be performed, all the bits in the ADANSA register should be set to 0 in single scan mode. The OCS bit should be set while the ADST bit is 0.

Do not use the first conversion result after the OCS bit is set to 1. Insert a stabilization wait time of 5  $\mu$ s after the first conversion is completed and before the second conversion is started.



# 27.2.13 A/D Sampling State Register n (ADSSTRn) (n = 0 to 4, 6, L, T, O)

Address(es): ADSSTR0: 0008 9060h, ADSSTR1: 0008 9073h, ADSSTR2: 0008 9074h, ADSSTR3: 0008 9075h, ADSSTR4: 0008 9076h, ADSSTR6: 0008 9078h, ADSSTRL: 0008 9061h, ADSSTRT: 0008 9070h, ADSSTRO: 0008 9071h



| Bit      | Symbol   | Bit Name                 | Description                                              | R/W |
|----------|----------|--------------------------|----------------------------------------------------------|-----|
| b7 to b0 | SST[7:0] | Sampling Time LO Setting | Sets the sampling time for each state (6 to 255 states). | R/W |

ADSSTRn sets the sampling time for analog input.

The actual sampling time is the register setting value + one state.

One state is one ADCLK (A/D conversion clock) cycle. When the ADCLK is 32 MHz, one state is 31.25 ns. The initial value is 20 states. If the impedance of the analog input signal source is too high to secure sufficient sampling time or if the ADCLK is slow, the sampling time can be adjusted. These bits should be set while the ADCSR.ADST bit is 0. The set value for sampling time should be between 6 to 255 states.

Table 27.7 shows the A/D sampling state registers and corresponding channels.

Table 27.7 A/D Sampling State Registers and Corresponding Channels

| Bit Name         | Corresponding Channels     |
|------------------|----------------------------|
| ADSSTR0.SST[7:0] | AN000                      |
| ADSSTR1.SST[7:0] | AN001                      |
| ADSSTR2.SST[7:0] | AN002                      |
| ADSSTR3.SST[7:0] | AN003                      |
| ADSSTR4.SST[7:0] | AN004                      |
| ADSSTR6.SST[7:0] | AN006                      |
| ADSSTRL.SST[7:0] | AN008 to AN015             |
| ADSSTRT.SST[7:0] | Temperature sensor output  |
| ADSSTRO.SST[7:0] | Internal reference voltage |

#### 27.3 Operation

### 27.3.1 Scanning Operation

In scanning, A/D conversion is performed sequentially on the analog inputs of the specified channels.

A scan conversion is performed in three operating modes: single scan mode, continuous scan mode, and group scan mode. Also, conversion modes are divided into high-speed conversion mode and normal conversion mode. In single scan mode, one or more specified channels are scanned once. In continuous scan mode, one or more specified channels are scanned repeatedly until the ADCSR.ADST bit is cleared to 0 from 1 by software. In group scan mode, the selected channels of group A and the selected channels of group B are scanned once after starting to be scanned according to the respective triggers.

In single scan mode and continuous scan mode, A/D conversion is performed for ANn channels selected by the ADANSA register, starting from the channel with the smallest number n. In group scan mode, A/D conversion is performed for ANn channels of group A and group B selected by the ADANSA and ADANSB registers, respectively, starting from the channel with the smallest number n.

High-speed mode can be selected when AVCC0  $\geq$  2.4 V. Normal conversion mode can be selected when AVCC0  $\geq$  1.8 V. High-speed mode reduces conversion time by six cycles compared to normal conversion mode.

When temperature sensor output or internal reference voltage is selected, single scan mode should be used for A/D conversion.

This operation is similar to the scan operation when only one channel is selected in single scan mode.

Double trigger mode is to be used with single scan mode or group scan mode. With double trigger mode being enabled, A/D conversion data of a channel selected by the ADCSR.DBLANS[4:0] bits is duplicated only if the conversion is started by any of the MTU triggers selected by the ADSTRGR.TRSA[3:0] bits.

In any scanning mode, the software trigger, synchronous trigger, or asynchronous trigger input to be used as the A/D conversion start condition is disabled while the ADCSR.ADST bit is 1 (during scanning process).

#### 27.3.2 Single Scan Mode

#### 27.3.2.1 Basic Operation

In basic operation of single scan mode, A/D conversion is performed once on the analog input of the specified channels as below. In selected channel scanning, the temperature sensor output A/D conversion select bit (ADEXICR.TSS) and the internal reference voltage A/D conversion select bit (ADEXICR.OCS) should be set to 0 (not selected). The following describes an operation when double trigger mode is not selected.

- (1) When the ADCSR.ADST bit is set to 1 (A/D conversion start) by software, synchronous trigger (MTU), or asynchronous trigger input, A/D conversion is performed for ANn channels selected by the ADANSA register, starting from the channel with the smallest number n.
- (2) Each time A/D conversion of a single channel is completed, the A/D conversion result is stored into the corresponding A/D data register (ADDRy).
- (3) When A/D conversion of all the selected channels is completed, an S12ADI0 interrupt request is generated if the ADCSR.ADIE bit is 1 (S12ADI0 interrupt upon scanning completion enabled).
- (4) The ADST bit remains 1 (A/D conversion start) during A/D conversion, and is automatically cleared to 0 when A/D conversion of all the selected channels is completed. Then the 12-bit A/D converter enters a wait state.



Figure 27.3 Example of Operation in Single Scan Mode (Basic Operation: AN003, AN004, AN006 Selected)

#### 27.3.2.2 A/D Conversion When Temperature Sensor Output is Selected

To perform A/D conversion of the temperature sensor output, make the following settings before starting conversion operation.

- Set the ADCSR.ADST bit to 0 (stops A/D conversion).
- Set the ADCSR.ADCS[1:0] bits to 00b (single scan mode).
- Set the ADANSA register to 0000h (all external analog inputs are not subject to conversion)
- Set the ADCSR.DBLE bit to 0 (deselects double trigger mode).
- Set the ADEXICR.TSS bit to 1 (A/D conversion of temperature sensor output is performed).
- Set the ADEXICR.OCS bit to 0 (A/D conversion of internal reference voltage is not performed).

Set an appropriate value in the ADSSTRO register to set the sampling time to 5 µs or longer.

Figure 27.4 shows the procedure for A/D conversion of the temperature sensor output.

- (1) Set the ADST bit to 1 (starts A/D conversion) to discharge the electric charge stored in the A/D converter ((1) in the figure).
  - Do not use the conversion result at this time.
- (2) When a trigger is input or the ADST bit is set to 1, A/D conversion is started for the temperature sensor output ((2) in the figure).
- (3) When A/D conversion is completed, the conversion result is stored into the ADTSDR register. If the ADCSR.ADIE bit is 1 (enables S12ADI0 interrupt generation upon scan completion.) at this time, an S12ADI0 interrupt request is generated ((3) in the figure).
- (4) The ADST bit is changed to 0 and the A/D converter enters waits a wait state ((4) in the figure).



Figure 27.4 Example of Operation in Single Scan Mode (Temperature Sensor Output Selected)

#### 27.3.2.3 A/D Conversion When Internal Reference Voltage is Selected

To perform A/D conversion of the internal reference voltage, make the following settings before starting conversion operation.

- Set the ADCSR.ADST bit to 0 (stops A/D conversion).
- Set the ADCSR.ADCS[1:0] bits to 00b (single scan mode).
- Set the ADANSA register to 0000h (all external analog inputs are not subject to conversion)
- Set the ADCSR.DBLE bit to 0 (deselects double trigger mode).
- Set the ADEXICR.TSS bit to 0 (A/D conversion of temperature sensor output is not performed).
- Set the ADEXICR.OCS bit to 1 (A/D conversion of internal reference voltage is performed).

Set an appropriate value in the ADSSTRO register to set the sampling time to 5 µs or longer.

Figure 27.5 shows the procedure for A/D conversion of the internal reference voltage.

- (1) Set the ADST bit to 1 (starts A/D conversion) to discharge the electric charge stored in the A/D converter ((1) in the figure).
  - Do not use the conversion result at this time.
- (2) When a trigger is input or the ADST bit is set to 1, A/D conversion is started for the internal reference voltage ((2) in the figure).
- (3) When A/D conversion is completed, the conversion result is stored into the ADOCDR register. If the ADCSR.ADIE bit is 1 (enables S12ADI0 interrupt generation upon scan completion.) at this time, an S12ADI0 interrupt request is generated ((3) in the figure).
- (4) The ADST bit is changed to 0 and the A/D converter enters waits a wait state ((4) in the figure).



Figure 27.5 Example of Operation in Single Scan Mode (Internal Reference Voltage Selected)

### 27.3.2.4 A/D Conversion in Double Trigger Mode

In single scan mode with double trigger mode, single scan operation started by synchronous trigger is performed twice as below.

The temperature sensor output A/D conversion select bit (ADEXICR.TSS) and the internal reference voltage A/D conversion select bit (ADEXICR.OCS) should be set to 0 (not selected).

Duplication of A/D conversion data is enabled by setting the channel numbers to be duplicated to the DBLANS[4:0] bits in ADCSR and setting the DBLE bit in ADCSR to 1. When the DBLE bit in ADCSR is set to 1, channel selection using the ADANSA register is invalid. In double trigger mode, synchronous triggers should be selected using the ADSTRGR.TRSA[3:0] bits, the ADCSR.EXTRG bit should be set to 0, and the ADCSR.TRGE bit should be set to 1. Software trigger should not be used.

- (1) When the ADCSR.ADST bit is set to 1 (A/D conversion start) by synchronous trigger input, A/D conversion is started on the single channel selected by the ADCSR.DBLANS[4:0] bits.
- (2) When A/D conversion is completed, the A/D conversion result is stored into the corresponding A/D data register (ADDRy).
- (3) The ADST bit is automatically cleared to 0 and the 12-bit A/D converter enters a wait state. Here, an S12ADI0 interrupt request is not generated irrespective of the ADIE (S12ADI0 interrupt upon scanning completion enabled) bit setting in ADCSR.
- (4) When the ADST bit in ADCSR is set to 1 (A/D conversion start) by the second trigger input, A/D conversion is started on the single channel selected by the DBLANS[4:0] bits in ADCSR.
- (5) When A/D conversion is completed, the A/D conversion result is stored into the A/D data duplication register (ADDBLDR), which is exclusively used in double trigger mode.
- (6) If the ADIE bit in ADCSR is 1 (S12ADI0 interrupt upon scanning completion enabled), an S12ADI0 interrupt request is generated.
- (7) The ADST bit remains 1 (A/D conversion start) during A/D conversion, and is automatically cleared to 0 when A/D conversion is completed. Then the 12-bit A/D converter enters a wait state.



Figure 27.6 Example of Operation in Single Scan Mode (Double Trigger Mode Selected; AN003 Duplicated)

#### 27.3.3 Continuous Scan Mode

#### 27.3.3.1 Basic Operation

In basic operation of continuous scan mode, A/D conversion is performed repeatedly on the analog input of the specified channels as below.

In continuous scan mode, the temperature sensor output A/D conversion select bit (ADEXICR.TSS) and the internal reference voltage A/D conversion select bit (ADEXICR.OCS) should both be set to 0 (not selected).

- (1) When the ADST bit in ADCSR is set to 1 (A/D conversion start) by software, synchronous trigger (MTU), or asynchronous trigger input, A/D conversion is performed for ANn channels selected by the ADANSA register, starting from the channel with the smallest number n.
- (2) Each time A/D conversion of a single channel is completed, the A/D conversion result is stored into the corresponding A/D data register (ADDRy).
- (3) When A/D conversion of all the selected channels is completed, an S12ADI0 interrupt request is generated if the ADIE bit in ADCSR is 1 (S12ADI0 interrupt upon scanning completion enabled).
  The 12-bit A/D converter sequentially starts A/D conversion for ANn channels selected by the ADANSA register, starting from the channel with the smallest number n.
- (4) The ADST bit in ADCSR is not automatically cleared to 0 and steps 2 and 3 are repeated as long as the bit remains 1 (A/D conversion start). When the ADST bit in ADCSR is set to 0 (A/D conversion stop), A/D conversion stops and the 12-bit A/D converter enters a wait state.
- (5) When the ADST bit is later set to 1 (A/D conversion start), A/D conversion is started again for ANn channels selected by the ADANSA register, starting from the channel with the smallest number n.



Figure 27.7 Example of Operation in Continuous Scan Mode (Basic Operation: AN000 to AN002 Selected)

#### 27.3.4 Group Scan Mode

#### 27.3.4.1 Basic Operation

In basic operation of group scan mode, A/D conversion is performed once on the analog inputs of all the specified channels in group A and group B after scanning is started by synchronous trigger as below. Scan operation of each group is similar to the scan operation in single scan mode.

The group A trigger and group B trigger can be selected using the TRSA[3:0] and TRSB[3:0] bits in ADSTRGR, respectively. The different triggers should be used for group A and group B to prevent simultaneous A/D conversion of group A and group B. Software trigger should not be used.

The group A and group B channels to be A/D-converted are selected using the ADANSA register and ADANSB register, respectively. Group A and group B cannot use the same channels.

In group scan mode, the temperature sensor output A/D conversion select bit (ADEXICR.TSS) and the internal reference voltage A/D conversion select bit (ADEXICR.OCS) should both be set to 0 (not selected).

The following describes operation in group scan mode using a trigger from the MTU. Specifically, the TRG0AN and TRG0BN triggers from the MTU are assumed to be used to start conversion of group A and group B, respectively.

- (1) Scanning of group A is started by the TRG0AN trigger from the MTU.
- (2) When group A scanning is completed, an S12ADI0 interrupt is output if the ADIE bit in ADCSR is 1 (S12ADI0 interrupt enabled).
- (3) Scanning of group B is started by the TRG0BN trigger from the MTU.
- (4) When group B scanning is completed, a GBADI interrupt is output if the GBADIE bit in ADCSR is 1 (GBADI interrupt enabled).



Figure 27.8 Example of Operation in Group Scan Mode (Basic Operation: MTU Triggers Used)

### 27.3.4.2 A/D Conversion in Double Trigger Mode

In group scan mode with double trigger mode, single scan operation started by synchronous trigger is performed twice for group A. For group B, single scan operation started by synchronous trigger is performed once.

In group scan mode, the group A trigger and group B trigger can be selected using the TRSA[3:0] and TRSB[3:0] bits in ADSTRGR, respectively. The different triggers should be used for group A and group B to prevent simultaneous A/D conversion of group A and group B. Software trigger, or asynchronous trigger (ADTRG0#) should not be used.

The group A and group B channels to be A/D-converted are selected using the DBLANS[4:0] bits in the ADCSR register and ADANSB register, respectively. The same channels cannot be selected for both groups.

In group scan mode, the temperature sensor output A/D conversion select bit (ADEXICR.TSS) and the internal reference voltage A/D conversion select bit (ADEXICR.OCS) should both be set to 0 (not selected).

Duplication of A/D conversion data is enabled by setting the channel numbers to be duplicated to the DBLANS[4:0] bits in ADCSR and setting the DBLE bit in ADCSR to 1.

The following describes operation in group scan mode with double trigger mode using a trigger from the MTU. Specifically, the TRG0BN and TRG0AN triggers from the MTU are assumed to be used to start conversion of group A and group B, respectively.

- (1) Scanning of group B is started by the TRG0AN trigger from the MTU.
- (2) When group B scanning is completed, a GBADI interrupt is output if the GBADIE bit in ADCSR is 1 (GBADI interrupt enabled).
- (3) The first scanning of group A is started by the first TRG0BN trigger from the MTU.
- (4) When the first scanning of group A is completed, the conversion result is stored into ADDRy; an S12ADI0 interrupt request is not generated irrespective of the ADIE bit setting in ADCSR.
- (5) The second scanning of group A is started by the second TRG0BN trigger from the MTU.
- (6) When the second scanning of group A is completed, the conversion result is stored into ADDBLDR. An S12ADI0 interrupt is output if the ADIE bit is 1 (S12ADI0 interrupt enabled).



Figure 27.9 Example of Operation in Group Scan Mode with Double Trigger Mode (Basic Operation: MTU Triggers Used)

# 27.3.4.3 Notes on Using Software Trigger

When a software trigger is input with double trigger mode selected, scanning of the selected channels is performed, and the S12ADI0 interrupt is output if the ADCSR.ADIE bit is 1 (enables S12ADI0 interrupt), regardless of scanning even or odd number of times. In addition, data is not duplicated even if scanning by a software trigger is performed even number of times.

The following shows an example when a software trigger is input while scanning by a synchronous trigger with double trigger mode selected.



Figure 27.10 Example of Double Trigger Operation When Using Software Trigger

### 27.3.5 Analog Input Sampling and Scan Conversion Time

Scan conversion can be activated either by software trigger; the triggers from the MTU, or ADTRG0# (external trigger). After start-of-scanning-delay time  $(t_D)$  has passed, then starts the A/D conversion process.

Figure 27.11 shows the scan conversion timing in single scan mode, in which scan conversion is activated by software trigger or triggers from the MTU. Figure 27.12 shows the scan conversion timing in single scan mode, in which scan conversion is activated by ADTRG0# (external trigger). The scan conversion time  $(t_{SCAN})$  includes start-of-scanning-delay time  $(t_{D})$ , A/D conversion processing time  $(t_{CONV})$ , and end-of-scanning-delay time  $(t_{ED})$ . Table 27.8 shows the specific scanning time.

The scan conversion time ( $t_{SCAN}$ ) in single scan mode for which the number of selected channels is n can be determined as follows:

$$t_{SCAN} = t_D + (t_{SPL} + t_{CONV}) n + t_{ED}$$

The scan conversion time for the first cycle in continuous scan mode is  $t_{SCAN}$  for single scan minus  $t_{ED}$ . The scan conversion time for the second and subsequent cycles in continuous scan mode is fixed to  $(t_{SPL} + t_{CONV})$  n.

|            |                 |                | ( 0 0 1 1 / 0 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 / 0 1 |  |
|------------|-----------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Table 27.8 | Scan Conversion | lime (in Terms | of PCLK and ADCLK Cycles)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |

| Item                             | Symbol            | Conditions                                    | Scan Conversion Time (Cycles)     |
|----------------------------------|-------------------|-----------------------------------------------|-----------------------------------|
| Start-of-scanning-delay time*1   | t <sub>D</sub>    | MTU, or software trigger                      | 2 PCLK + 3 ADCLK                  |
|                                  |                   | External trigger                              | 4 PCLK + 3 ADCLK                  |
| Sampling time*1                  | t <sub>SPL</sub>  | ADSSTRn.SST[7:0] bits (initial set value 14h) | (register set value + 1)<br>ADCLK |
| A/D conversion processing time*1 | t <sub>CONV</sub> | High-speed mode                               | 23 ADCLK                          |
|                                  |                   | Normal-speed mode                             | 29 ADCLK                          |
| Scan conversion time*1           | t <sub>ED</sub>   | _                                             | 1 PCLK + 2 ADCLK*2                |

Note 1. For  $t_{\text{D}},\,t_{\text{SPL}},\,t_{\text{CONV}},$  and  $t_{\text{ED}},$  see Figure 27.11 and Figure 27.12.

Note 2. The value of 2 ADCLK is fixed and an interrupt is output within plus 1 PCLK. For details on the processing time for termination, refer to section 27.6.3, A/D Conversion Restarting Timing and Termination Timing.



Figure 27.11 Scan Conversion Timing (Activated by Software, or Triggers from the MTU)



Figure 27.12 Scan Conversion Timing (Activated by ADTRG0#)

#### 27.3.6 Usage Example of Automatic Register Clearing Function

Setting the ADCER.ACE bit to 1 automatically clears the A/D data registers (ADDRy, ADOCDR, ADTSDR, and ADDBLDR) to 0000h when the A/D data registers are read by the CPU or DTC.

This function enables detection of update failures of the A/D data registers. The following describes the examples in which the function to automatically clear the ADDRy register is enabled and disabled.

In a case where the ADCER.ACE bit is 0 (automatic clearing is disabled), if the A/D conversion result (0222h) is not written to the ADDRy register for some reason, the old data (0111h) will be the ADDRy value. Furthermore, if this ADDRy value is written to a general register using an A/D scan end interrupt, the old data (0111h) can be saved in the general register. When checking whether there is an update failure, it is necessary to frequently save the old data in the RAM or a general register.

In a case where the ADCER.ACE bit is 1 (automatic clearing is enabled), when ADDRy = 0111h is read by the CPU, DTC, or ADDRy is automatically cleared to 0000h. After that, if the A/D conversion result 0222h cannot be transferred to ADDRy for some reason, the cleared data (0000h) remains as the ADDRy value. If this ADDRy value is read into a general register using an A/D scan end interrupt at this point, 0000h will be saved in the general register. Occurrence of an ADDRy update failure can be determined by simply checking that the read data value is 0000h.

#### 27.3.7 A/D-Converted Value Addition Function

The same channel is A/D converted two to four consecutive times and the sum of the converted values is stored in the data register. The use of the average of these results can improve the accuracy of A/D conversion, depending on the types of noise components that are present. This function, however, cannot always guarantee an improvement in A/D conversion accuracy.

A/D converted value addition function can be used at the time of selecting the channel selection analog input A/D conversion, temperature sensor output A/D conversion, or A/D internal reference voltage A/D conversion.

### 27.3.8 Starting A/D Conversion with an Asynchronous Trigger

The A/D conversion can be started by the input of an asynchronous trigger. To start up the A/D converter by an asynchronous trigger, the A/D conversion start trigger select bits (ADSTRGR.TRSA[3:0]) should be set to 0000b and a high-level signal should be input to the asynchronous trigger (ADTRG0# pin), and both the ADCSR.TRGE and ADCSR.EXTRG bits should be set to 1. Figure 27.13 shows a timing of the asynchronous trigger input. For the time required for the A/D conversion start after the ADCSR.ADST bit is set, refer to section 27.6.3, A/D Conversion Restarting Timing and Termination Timing.

An asynchronous trigger cannot be selected by the A/D conversion start trigger select bits (ADSTRGR.TRSA[3:0]) for group B to be used in group scan mode.



Figure 27.13 Asynchronous Trigger Input Timing

#### 27.3.9 Starting A/D Conversion with Synchronous Trigger from Peripheral Modules

The A/D conversion can be started by a synchronous trigger of the MTU. To start the A/D conversion by a synchronous trigger, the ADCSR.TRGE bit should be set to 1, the ADCSR.EXTRG bit should be cleared to 0, and the relevant source should be selected by ADSTRGR.TRSA[3:0] and TRSB[3:0] bits.

The A/D conversion startup sources for group B to be used in group scan mode should be selected by the ADSTRGR.TRSB[3:0] bits. In group scan mode, the different A/D start conversion startup sources should be selected by the ADSTRGR.TRSA[3:0] bits and the ADSTRGR.TRSB[3:0] bits.

#### 27.4 Interrupt Sources

#### 27.4.1 Interrupt Request on Completion of Each Scanning Conversion

The 12-bit A/D converter can send scan end interrupt requests S12ADI0 and GBADI to the CPU.

Setting the ADCSR.ADIE bit to 1 and 0 enables and disables an S12ADI0 interrupt, respectively. Similarly, setting the ADCSR.GBADIE bit to 1 and 0 enables and disables a GBADI interrupt, respectively.

In addition, the DTC can be started up when an S12ADI0 or a GBADI interrupt is generated. Using an S12ADI0 or a GBADI interrupt to allow the DTC to read the converted data enables continuous conversion without burden on software. For details on DTC settings, refer to section 16, Data Transfer Controller (DTCa).

### 27.5 A/D Conversion Accuracy Definitions

The A/D conversion accuracy is defined as below:

• Resolution

The number of 12-bit A/D converter digital output codes

Offset error

The deviation of the analog input voltage value from the ideal A/D conversion characteristic when the digital output changes from the minimum voltage value 000000000000 to 00000000001, excluding quantization error.

• Full-scale error

The deviation of the analog input voltage value from the ideal A/D conversion characteristic when the digital output changes from 111111111110 to 1111111111111, excluding quantization error.

• Quantization error

The deviation inherent in the 12-bit A/D converter, given by 1/2 LSB

• Nonlinearity error

The error with respect to the ideal A/D conversion characteristic between zero voltage and the full-scale error, excluding offset error, full-scale error, and quantization error.

• Absolute accuracy

The deviation between the digital value and analog input value, including offset error, full-scale error, quantization error, and nonlinearity error.

#### 27.6 Usage Notes

### 27.6.1 Notes on Reading Data Registers

The A/D data registers, A/D data duplication register, A/D temperature sensor data register, and A/D internal reference voltage data register should be read in word units. If a register is read twice in byte units, that is, the higher-order byte and lower-order byte are separately read, the A/D converted value having been read first may disagree with the A/D converted value having been read for the second time. To prevent this, the data registers should never be read in byte units.

### 27.6.2 Notes on Stopping A/D Conversion

To stop A/D conversion when an asynchronous trigger or a synchronous trigger has been selected as the condition for starting A/D conversion, set the ADCSR.TRGE bit to 0 and select the software trigger as the condition for starting A/D conversion, and then set the ADCSR.TRGE bit to 0 (to stop A/D conversion).

### 27.6.3 A/D Conversion Restarting Timing and Termination Timing

It takes a maximum of four ADCLK cycles for the idle analog unit of the 12-bit A/D converter to be restarted by setting the ADCSR.TRGE bit to 1. It takes a maximum of two ADCLK cycles for the operating analog unit of the 12-bit A/D converter to be terminated by setting the ADCSR.TRGE bit to 0.

#### 27.6.4 Notes on Scan End Interrupt Handling

When scanning the same analog input twice using any trigger, the first A/D converted data is overwritten with the second A/D converted data in the case that the CPU does not complete reading the A/D converted data by the time the A/D conversion of the first analog input for the second scan ends after the first scan end interrupt is generated.

### 27.6.5 Module Stop Function Setting

Operation of the 12-bit A/D converter can be disabled or enabled by setting module stop control register A (MSTPCRA). The initial setting is for operation of the 12-bit A/D converter to be halted. Register access is enabled by releasing the module stop state.

After the module stop state is released, wait for 1  $\mu$ s to start A/D conversion. For details, refer to section 11, Low Power Consumption.

#### 27.6.6 Notes on Entering Low Power Consumption States

Before entering module stop mode or software standby mode, make sure to stop A/D conversion. Here, set the ADCSR.ADST bit to 0, and allow time for stopping the analog unit of the 12-bit A/D converter. Follow the procedure given below to secure this time.

- 1. Set the ADCSR.TRGE bit to 0 (software trigger).
- 2. Set the ADCSR.ADST bit to 0.
- 3. After confirming that the A/D converter has been stopped, place the MCU in the module stop state mode or software standby mode.

# 27.6.7 Notes on Releasing Software Standby Mode

After software standby mode is released, wait until the crystal oscillation stabilization time elapses, and then wait for 1  $\mu$ s before starting A/D conversion. For details, refer to section 11, Low Power Consumption.



### 27.6.8 Allowable Impedance of Signal Source

To achieve high-speed conversion of 1.0  $\mu$ s, the analog input pins of this MCU are designed so that the conversion accuracy is guaranteed if the impedance of the input signal source is 0.3  $\mu$ 0 or less. If an external capacitor of large capacitance is attached in the application in which only a single pin input is converted in single scan mode, the only load on input is virtually 2.6  $\mu$ 0 of the internal input resistor; therefore, the impedance of the signal source can be ignored. Being a low-pass filter, however, an analog input circuit may not follow the analog signal with a large differential coefficient as shown in Figure 27.14. When high-speed analog signals are to be converted or multiple pins are to be converted in scan mode, a low-impedance buffer should be used.



Figure 27.14 Internal Equivalent Circuit of Analog Input Pin

Figure 27.15 shows an equivalent circuit of an analog input pin and an external sensor.

To perform A/D conversion accurately, charging of the internal capacitor C shown in Figure 27.15 must be completed within the specified period of time. This specified period is referred to as sampling time.



Figure 27.15 Equivalent Circuit of Analog Input Pin and External Sensor

Let the sampling time be T [s], the output impedance of the sensor be R0 [ $\Omega$ ], the internal resistance of the MCU be R [ $\Omega$ ], the accuracy (error) of the A/D converter be x [LSB], and the resolution of the A/D converter be y [tone] (4096 in 12-bit mode), the voltage difference VC between both sides of the capacitor C is expressed as follows:

$$VC = VIN \left\{ 1 - e^{-\frac{T}{C\left(R0 + R\right)}} \right\}$$

When t = T, to obtain a conversion error of x or less,

$$VC = VIN - \frac{x}{y}VIN = VIN\left(1 - \frac{x}{y}\right)$$

Thus, R0 can be calculated as follows:

$$e^{-\frac{T}{C(R0+R)}} = \frac{x}{y}$$

$$-\frac{T}{C(R0+R)} = \ln \frac{x}{y}$$

$$R0 = -\frac{T}{C\ln \frac{x}{y}} - R$$

When fPCLKD = 32 MHz, the output impedance R0 of the sensor for an error of 0.1 LSB or less is obtained by the following equation:

 $T=0.3~\mu s,~x=0.1,~y=4096,~R=2.6~k\Omega$  (reference value), and C=7~pF (reference value) Hence,

$$R0 = -\frac{0.3 \times 10^{-6}}{7 \times 10^{-12} \times 1n \left(\frac{0.1}{4096}\right)} - 2.6 \times 10^{3}$$
$$= 1435$$

Thus, the output impedance R0 of the sensor must be approximately 1.4 k $\Omega$  or less to obtain the A/D converter accuracy (error) of 0.1 LSB or less.

Actual error, however, is the value of absolute accuracy added to the above 0.1 LSB.

These values are for reference and operation must be verified by performing evaluations.



#### 27.6.9 Influence on Absolute Accuracy

Attaching a capacitor creates coupling with GND and may affect the absolute accuracy when noisy GND is used; therefore, a capacitor should be connected to electrically stable GND such as AVSSO.

The filter circuit should be designed so that it does not interfere digital signals or it does not serve as an antenna on the circuit board.

#### 27.6.10 Voltage Range of Analog Power Supply Pins

If this MCU is used with the voltages outside the following ranges, the reliability of the MCU may be affected.

- Analog input voltage range
  - Voltage (VAN) applied to analog input pins ANn:  $VREFL0 \le VAN \le VREFH0$
  - Reference voltage range applied to the VREFH0 pin: VREFH0 ≤ AVCC0
  - Voltage applied to analog input pins ANn (n = 0 to 4, 6):  $AVSS0 \le VAN \le AVCC0$
  - Voltage applied to analog input pins ANn (n = 8 to 15):  $VSS \le VAN \le VCC$  and  $VSS \le VAN \le AVCC$
- Relationship between power supply pin pairs (AVCC0–AVSS0, VREFH0–VREFL0, VCC–VSS)

  The following condition should be satisfied: AVSS0 = VSS. A 0.1-μF capacitor should be connected between each pair of power supply pins to create a closed loop with the shortest route possible as shown in Figure 27.16, and connection should be made so that the following conditions are satisfied at the supply side.

```
VREFL0 = AVSS0 = VSS
```

When the 12-bit A/D converter is not used, the following conditions should be satisfied.

AVCC0 = VCC and AVSS0 = VSS



Figure 27.16 Power Supply Pin Connection Example

#### 27.6.11 Notes on Board Design

The board should be designed so that digital circuits and analog circuits are separated from each other as far as possible. In addition, digital circuit signal lines and analog circuit signal lines should not intersect or placed near each other. If these rules are not followed, noise will be produced on analog signals and A/D conversion accuracy will be affected. The analog input pins (AN000 to AN004, AN006, AN008 to AN015), reference power supply pin (VREFH0), reference ground pin (VREFL0), and analog power supply (AVCC0) should be separated from digital circuits using the analog ground (AVSS0). The analog ground (AVSS0) should be connected to a stable digital ground (VSS) on the board (single-point ground plane connection).

#### 27.6.12 Notes on Noise Prevention

To prevent the analog input pins (AN000 to AN004, AN006, AN008 to AN015) from being destroyed by abnormal voltage such as excessive surge, a capacitor should be inserted between AVCC0 and AVSS0 and between VREFH0 and VREFL0, and a protection circuit should be connected to protect the analog input pins (AN000 to AN004, AN006, AN008 to AN015) as shown Figure 27.17.



Figure 27.17 Sample Protection Circuit for Analog Inputs

### 27.6.13 Port Setting When 12-Bit A/D Converter Inputs are Used

When the 12-bit A/D converter is used, output from port 4 should not be used. This is because an analog power supply is used for parts of the port 4 circuits.

### 27.6.14 Sequence of Powering on AVCC0 and VCC

When powering on AVCC0 and VCC, power them on at the same time or VCC first.

# 28. Temperature Sensor (TEMPSA)

#### 28.1 Overview

This MCU includes a temperature sensor. The temperature sensor outputs a voltage which varies with the temperature. The user can obtain the temperature surrounding the MCU using the 12-bit A/D converter to convert the voltage output from the temperature sensor into a digital value.

Table 28.1 lists the specifications of the temperature sensor. Figure 28.1 shows a overall block diagram of the temperature sensor system.

Table 28.1 Temperature Sensor Specifications

| Item                              | Description                                                           |
|-----------------------------------|-----------------------------------------------------------------------|
| Temperature sensor voltage output | The temperature sensor voltage is output to the 12-bit A/D converter. |



Figure 28.1 Block Diagram of Temperature Sensor System

### 28.2 Register Descriptions

### 28.2.1 Temperature Sensor Calibration Data Register (TSCDRH, TSCDRL)





Address(es): TSCDRH 007F C0ADh



The TSCDRH and TSCDRL registers store temperature sensor calibration data measured for each chip at factory shipment.

Temperature sensor calibration data is a digital value obtained using the 12-bit A/D converter to convert the voltage output by the temperature sensor under the condition  $Ta = Tj = 88^{\circ}C$  and AVCC0 = VREFH0 = 3.3 V. The TSCDRH register stores the higher 4 bits of the converted value, and the TSCDRL register stores the lower 8 bits.

# 28.3 Using the Temperature Sensor

The temperature sensor outputs a voltage which varies with the temperature. The user can obtain the temperature surrounding the MCU using the 12-bit A/D converter to convert this voltage into a digital value.

#### 28.3.1 Before Using the Temperature Sensor

The temperature characteristics of the temperature sensor are shown below. The voltage output by the temperature sensor is proportional to the temperature, which can be calculated according to the formula below.

Formula for the temperature characteristic:

T = (Vs - V1)/Slope + T1

T: Measured temperature (°C)

Vs: Voltage output by the temperature sensor when the temperature is measured (V)

T1: Sample temperature measurement at first point (°C)

V1: Voltage output by the temperature sensor when T1 is measured (V)

T2: Sample temperature measurement at second point (°C)

V2: Voltage output by the temperature sensor when T2 is measured (V)

(V2 - V1)/(T2 - T1) =Slope: Temperature gradient of the temperature sensor  $(V/^{\circ}C)$ 

Characteristics vary from sensor to sensor. Therefore, it is recommended that two different sample temperatures are measured.

Use the 12-bit A/D converter to measure the voltage V1 output by the temperature sensor at temperature T1. Again, using the 12-bit A/D converter, measure the voltage V2 output by the temperature sensor at a different temperature T2. Obtain the temperature gradient (Slope = (V2 - V1)/(T2 - T1)) from these results. Subsequently, obtain temperatures by substituting the slope into the formula for the temperature characteristic (T = (Vs - V1)/Slope + T1).

If you are using the temperature gradient given in section 32, Electrical Characteristics, use the A/D converter to measure the voltage V1 output by the temperature sensor at temperature T1, and then calculate the temperature characteristic by using the formula below.

However, this method produces less accurate temperatures than measurement at two points.

$$T = (Vs - V1)/Slope + T1$$

In this MCU, the TSCDRH and TSCDRL registers store the temperature value (CAL88) of the temperature sensor measured under the condition  $Ta = Tj = 88^{\circ}C$  and AVCC0 = VREFH0 = 3.3 V. By using this value as the sample measurement result at the first point, preparation before using the temperature sensor can be omitted. This measured value  $CAL_{88}$  can be calculated as follows:

CAL<sub>88</sub> = (TSCDRH register value << 8) + TSCDRL register value

If V1 is calculated from CAL<sub>88</sub>,

$$V1 = 3.3 \times CAL_{88}/4096 [V]$$

Using this, the measured temperature can be calculated according to the formula below.

T = (Vs - V1)/Slope + 88 [°C]

T: Measured temperature (°C)

Vs: Voltage output by the temperature sensor when the temperature is measured (V)

V1: Voltage output by the temperature sensor when  $Ta = Tj = 88^{\circ}C$  and AVCC0 = VREFH0 = 3.3 V (V)

Slope: Temperature gradient listed in Table 5.46  $\div$  1000 (V/ $^{\circ}$ C)

Error in the measured temperature (variation range is  $3\sigma$ ) is shown in Figure 28.2.



Figure 28.2 Error in the Measured Temperature (Designed Value)

### 28.3.2 Setting the 12-Bit A/D Converter

The temperature sensor can provide temperature data through the A/D conversion of the temperature sensor output. In order to A/D convert output from the temperature sensor, 12-bit A/D converter registers must be set as follows.

- Selecting the temperature sensor voltage as an A/D conversion target
   Set the ADEXICR.TSS bit to 1 to A/D convert temperature sensor output. Additionally, remove other sources from the scope of conversion by setting all the bits in registers ADANSA and ADANSB to 0.
- Setting single scan mode
   Set the ADCSR.ADCS[1:0] bits to 00b to select single scan mode. Do not select the other mode.

#### 28.3.3 A/D Conversion Result of Temperature Sensor Output

After the temperature sensor output is A/D converted, the conversion result is stored in the ADTSDR register. Set the sampling time to 5  $\mu$ s or longer. After switching to A/D conversion of the temperature sensor output, set the ADST bit to 1 and start the first conversion. However, do not use the first conversion result. Figure 28.3 shows an example of operating the temperature sensor.



Figure 28.3 Example of Temperature Sensor Operation

# 29. Data Operation Circuit (DOC)

### 29.1 Overview

The data operation circuit (DOC) is used to compare, add, and subtract 16-bit data.

Table 29.1 lists the data operation circuit specifications and Figure 29.1 shows a block diagram of the data operation circuit.

16-bit data is compared and an interrupt can be generated when a selected condition applies.

Table 29.1 DOC Specifications

| Item                             | Description                                                                                                                                                                                       |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data operation function          | 16-bit data comparison, addition, and subtraction                                                                                                                                                 |
| Lower power consumption function | Module stop state can be set.                                                                                                                                                                     |
| Interrupts                       | An interrupt occurs at the following timings:  The compared values either match or mismatch  The result of data addition is greater than FFFFh  The result of data subtraction is less than 0000h |



Figure 29.1 DOC Block Diagram

### 29.2 Register Descriptions

### 29.2.1 DOC Control Register (DOCR)

Address(es): 0008 B080h



| Bit    | Symbol   | Bit Name                                   | Description                                                                                                                                                  | R/W |
|--------|----------|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1, b0 | OMS[1:0] | Operating Mode Select                      | <ul> <li>b1 b0</li> <li>0 0: Data comparison mode</li> <li>1: Data addition mode</li> <li>0: Data subtraction mode</li> <li>1: Setting prohibited</li> </ul> | R/W |
| b2     | DCSEL*1  | Detection Condition Select                 | Result of data comparison 0: Data mismatch is detected. 1: Data match is detected.                                                                           | R/W |
| b3     | _        | Reserved                                   | This bit is read as 0. The write value should be 0.                                                                                                          | R/W |
| b4     | DOPCIE   | Data Operation Circuit<br>Interrupt Enable | cuit 0: Disables interrupts from the data operation circuit.  1: Enables interrupts from the data operation circuit.                                         |     |
| b5     | DOPCF    | Data Operation Circuit Flag                | Indicates the result of an operation.                                                                                                                        | R   |
| b6     | DOPCFCL  | DOPCF Clear                                | Maintains the DOPCF flag state.     Clears the DOPCF flag.                                                                                                   | R/W |
| b7     | _        | Reserved                                   | This bit is read as 0. The write value should be 0.                                                                                                          | R/W |

Note 1. Valid only when data comparison mode is selected.

#### OMS[1:0] Bits (Operating Mode Select)

These bits select the operating mode of the data operation circuit.

#### **DCSEL Bit (Detection Condition Select)**

This bit is valid only when data comparison mode is selected.

This bit selects the condition for detection in data comparison mode.

#### **DOPCIE Bit (Data Operation Circuit Interrupt Enable)**

Setting this bit to 1 enables interrupts from the data operation circuit.

#### **DOPCF Flag (Data Operation Circuit Flag)**

[Setting conditions]

- The condition selected by the DCSEL bit is met
- A result of data addition is greater than FFFFh
- A result of data subtraction is less than 0000h

[Clearing condition]

• Writing 1 to the DOPCFCL bit

#### **DOPCFCL Bit (DOPCF Clear)**

Setting this bit to 1 clears the DOPCF flag.

This bit is read as 0.

# 29.2.2 DOC Data Input Register (DODIR)

Address(es): 0008 B082h



DODIR is a 16-bit readable/writable register in which 16-bit data for use in the operations are stored.

# 29.2.3 DOC Data Setting Register (DODSR)

Address(es): 0008 B084h



DODSR is a 16-bit readable/writable register. This register stores 16-bit data for use as a reference in data comparison mode. This register also stores the results of operations in data addition and data subtraction modes.

### 29.3 Operation

### 29.3.1 Data Comparison Mode

Figure 29.2 shows an example of the steps involved in data comparison mode operation by the data operation circuit. The following is an example of operation when DCSEL is set to 0 (data mismatch is detected as a result of data comparison).

- (1) Writing 00b to the DOCR.OMS[1:0] bits selects data comparison mode.
- (2) The 16-bit reference data is set in DODSR.
- (3) 16-bit data for comparison is written to DODIR.
- (4) Writing of 16-bit data continues until all data for comparison have been written to DODIR.
- (5) If a value written to DODIR does not match that in DODSR\*1, the DOCR.DOPCF flag is set to 1. When the DOCR.DOPCIE bit is 1, a data operation circuit interrupt is also generated.

Note 1. When DOCR.DCSEL = 0



Figure 29.2 Example of Operation in Data Comparison Mode

#### 29.3.2 Data Addition Mode

Figure 29.3 shows an example of the steps involved in data addition mode operation by the data operation circuit.

- (1) Writing 01b to the DOCR.OMS[1:0] bits selects data addition mode.
- (2) 16-bit data is set in the DODSR register as the initial value.
- (3) 16-bit data to be added is written to DODIR. The result of the operation is stored in DODSR.
- (4) Writing of 16-bit data continues until all data for addition have been written to DODIR.
- (5) If the result of an operation is greater than FFFFh, the DOCR.DOPCF flag is set to 1. When the DOCR.DOPCIE bit is 1, a data operation circuit interrupt is also generated.



Figure 29.3 Example of Operation in Data Addition Mode

#### 29.3.3 Data Subtraction Mode

Figure 29.4 shows an example of the steps involved in data subtraction mode operation by the data operation circuit.

- (1) Writing 10b to the DOCR.OMS[1:0] bits selects data subtraction mode.
- (2) 16-bit data is set in the DODSR register as the initial value.
- (3) 16-bit data to be subtracted is written to DODIR. The result of the operation is stored in DODSR.
- (4) Writing of 16-bit data continues until all data for subtraction have been written to DODIR.
- (5) If the result of an operation is less than 0000h, the DOCR.DOPCF flag is set to 1. When the DOCR.DOPCIE bit is 1, a data operation circuit interrupt is also generated.



Figure 29.4 Example of Operation in Data Subtraction Mode

#### 29.4 Interrupt Requests

The data operation circuit generates the data operation circuit interrupt as an interrupt request. When an interrupt source is generated, the data operation circuit flag corresponding to the interrupt is set to 1. Table 29.2 describes the interrupt request.

Table 29.2 Interrupt Request from Data Operation Circuit

| Interrupt Request                | Data Operation Circuit Flag | Interrupt Generation Timing                                                                                                                                                            |
|----------------------------------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data operation circuit interrupt | DOPCF                       | <ul> <li>The compared values either match or mismatch</li> <li>The result of data addition is greater than FFFFh</li> <li>The result of data subtraction is less than 0000h</li> </ul> |

#### 29.5 Usage Note

#### 29.5.1 Module Stop Function Setting

Operation of the data operation circuit can be disabled or enabled using module stop control register B (MSTPCRB). The initial setting is for the data operation circuit to be stopped. Register access is enabled by releasing the module stop state. For details, refer to section 11, Low Power Consumption.

RX110 Group 30. RAM

#### 30. RAM

This MCU has an on-chip high-speed static RAM.

#### 30.1 Overview

Table 30.1 lists the specifications of the RAM.

Table 30.1 RAM Specifications

| Item                           | Description                                                                                                                  |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| RAM capacity                   | Max. 16 Kbytes* <sup>2</sup>                                                                                                 |
| Access                         | <ul> <li>Single-cycle access is possible for both reading and writing.</li> <li>RAM can be enabled or disabled.*1</li> </ul> |
| Low power consumption function | Module stop state can be set.                                                                                                |

Note 1. Selectable by the SYSCR1.RAME bit. For details on the SYSCR1 register, refer to section 3.2.2, System Control Register 1 (SYSCR1).

Note 2. The capacity of RAM differs depending on the products.

| RAM Capacity | RAM Address                    |
|--------------|--------------------------------|
| 16 Kbytes    | RAM0: 0000 0000h to 0000 3FFFh |
| 10 Kbytes    | RAM0: 0000 0000h to 0000 27FFh |
| 8 Kbytes     | RAM0: 0000 0000h to 0000 1FFFh |

# 30.2 Operation

### 30.2.1 Low Power Consumption Function

Power consumption can be reduced by setting module stop control register C (MSTPCRC) to stop supply of the clock signal to the RAM.

Setting the MSTPCRC.MSTPC0 bit to 1 stops supply of the clock signal to RAM0.

Stopping supply of the clock signal places the RAM0 in the module stop state. The RAM operates after the value is initialized by a reset.

The RAM is not accessible in the module stop state. Do not make a transition to the module stop state while the RAM is being accessed.

For details on the MSTPCRC register, refer to section 11, Low Power Consumption.

# 31. Flash Memory

This MCU has packages with 8, 16, 32, 64, 96, and 128 Kbyte flash memory (ROM) for storing code for storing data. In this section, "PCLK" is used to refer to PCLKB.

#### 31.1 Overview

Table 31.1 lists the Flash Memory Specifications.

Table 31.6 lists the I/O Pins Used in Boot Mode.

Table 31.1 Flash Memory Specifications

| Item                        | Description                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory space                | <ul> <li>User area: Up to 128 Kbytes</li> <li>Extra area: Stores the start-up area information, access window information, and unique ID</li> </ul>                                                                                                                                                                                                            |
| Software commands           | The following commands are implemented: Program, blank check, block erase, unique ID read The following commands are implemented for programming the extra area: Start-up area information program, access window information program                                                                                                                          |
| Value after erase           | • ROM: FFh                                                                                                                                                                                                                                                                                                                                                     |
| Interrupt                   | An interrupt (FRDYI) is generated upon completion of software command processing or forced stop processing.                                                                                                                                                                                                                                                    |
| On-board programming        | Boot mode (SCI)*1  Channel 1 of the serial communications interface (SCI1) is used for asynchronous serial communication.  The user area is rewritable.  Boot mode (FINE interface)*1  The FINE is used.  The user area is rewritable.  Self-programming in single-chip mode  The user area is rewritable using the flash rewrite routine in the user program. |
| Off-board programming       | The user area is rewritable using a flash programmer compatible with this MCU.                                                                                                                                                                                                                                                                                 |
| ID code protection          | <ul> <li>Connection with the serial programmer can be enabled or disabled using ID codes in boot mode.</li> <li>Connection with the on-chip debugging emulator can be enabled or disabled using ID codes.</li> </ul>                                                                                                                                           |
| Start-up program protection | This function is used to safely rewrite block 0 to block 15.                                                                                                                                                                                                                                                                                                   |
| Area protection             | This function enables rewriting only the selected blocks in the user area and disables the other blocks during self-programming.                                                                                                                                                                                                                               |

Note 1. Refer to "PG-FP5 Flash Memory Programmer User's Manual" and "Renesas Flash Programmer Flash memory programming software User's Manual" for more details.

## 31.2 ROM Area and Block Configuration

The maximum ROM size of this MCU is 128 Kbytes. The ROM area is divided into blocks. A block is 1-Kbyte area. When executing the block erase command, the memory is erased by the block. Figure 31.1 shows the ROM Area and Block Configuration.



Figure 31.1 ROM Area and Block Configuration

Table 31.2 Correspondence Between ROM Capacity and Addresses for Reading

| ROM Capacity | Addresses for Reading    |  |
|--------------|--------------------------|--|
| 128 Kbytes   | FFFE 0000h to FFFF FFFFh |  |
| 96 Kbytes    | FFFE 8000h to FFFF FFFFh |  |
| 64 Kbytes    | FFFF 0000h to FFFF FFFFh |  |
| 32 Kbytes    | FFFF 8000h to FFFF FFFFh |  |

Table 31.2 Correspondence Between ROM Capacity and Addresses for Reading

| ROM Capacity | Addresses for Reading    |
|--------------|--------------------------|
| 16 Kbytes    | FFFF C000h to FFFF FFFFh |
| 8 Kbytes     | FFFF E000h to FFFF FFFFh |

### 31.3 Register Descriptions

### 31.3.1 Flash P/E Mode Entry Register (FENTRYR)

Address(es): 007F FFB2h



| Bit       | Symbol     | Bit Name             | Description                                                                                                                                                                                                                                           | R/W |
|-----------|------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0        | FENTRY0    | ROM P/E Mode Entry 0 | <ul><li>0: ROM is in read mode.</li><li>1: ROM can be placed in P/E mode.</li></ul>                                                                                                                                                                   | R/W |
| b7 to b1  | _          | Reserved             | These bits are read as 0. The write value should be 0.                                                                                                                                                                                                | R/W |
| b15 to b8 | FEKEY[7:0] | Key Code             | The FEKEY[7:0] bits are used to control rewriting of the FENTRYR register.  When rewriting the value of the low-order 8 bits, set the FEKEY[7:0] bits to AAh at the same time (write this register in 16 bits).  The FEKEY[7:0] bits are read as 00h. | R/W |

To rewrite the ROM, the FENTRY0 bit must be set to 1 to place the ROM in P/E mode.

When returning to read mode, set the FENTRYR register and confirm that its value has been rewritten before reading the ROM.

Refer to section 31.6.1, Sequencer Modes for details on P/E mode and read mode.

#### FENTRY0 Bit (ROM P/E Mode Entry 0)

This bit is used to place the ROM in P/E mode.

[Setting condition]

• AA01h is written to the FENTRYR register when the FENTRYR register is 0000h.

Note: When entering ROM P/E mode, the instruction fetch address must be transferred to an area other than the ROM so that instruction fetching is not executed to the ROM. Copy necessary instruction code to the internal RAM and jump to the RAM.

[Clearing condition]

• AA00h is written to the FENTRYR register.

## 31.3.2 Protection Unlock Register (FPR)

Address(es): 007F C0C0h



This write-only register is used to protect the FPMCR register from being rewritten inadvertently when the CPU runs out of control. Writing to the FPMCR register is enabled only when the following procedure is used to access the register.

## Procedure to unlock protection

- (1) Write A5h to the FPR register.
- (2) Write a set value to the FPMCR register.
- (3) Write the inverted set value to the FPMCR register.
- (4) Write a set value to the FPMCR register again.

When a procedure other than the above is used to write data, the FPSR.PERR flag is set to 1.

## 31.3.3 Protection Unlock Status Register (FPSR)

Address(es): 007F C0C1h



| Bit      | Symbol | Bit Name           | Description                        | R/W |
|----------|--------|--------------------|------------------------------------|-----|
| b0       | PERR   | Protect Error Flag | 0: No error<br>1: An error occurs. | R   |
| b7 to b1 | _      | Reserved           | These bits are read as 0.          | R   |

#### PERR Flag (Protect Error Flag)

When the FPMCR register is not accessed as described in the procedure to unlock protection, data is not written to the register and this flag is set to 1.

[Setting condition]

• The FPMCR register is not accessed as described in the procedure to unlock protection.

[Clearing condition]

 The FPMCR register is accessed according to the procedure to unlock protection described in section 31.3.2, Protection Unlock Register (FPR).

## 31.3.4 Flash P/E Mode Control Register (FPMCR)

Address(es): 007F FF80h



| Bit | Symbol | Bit Name                      | Description                                                                                                                                       | R/W |
|-----|--------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0  | _      | Reserved                      | This bit is read as 0. The write value should be 0.                                                                                               | R/W |
| b1  | FMS0   | Flash Operating Mode Select 0 | FMS2 FMS1 FMS0 0 0 0: ROM read mode 0 1 1: Discharge mode 1 1 0 1: ROM P/E mode 1 1 1: Discharge mode 2 Settings other than above are prohibited. | R/W |
| b2  | _      | Reserved                      | This bit is read as 0. The write value should be 0.                                                                                               | R/W |
| b3  | RPDIS  | ROM P/E Disable               | ROM programming/erasure enabled     ROM programming/erasure disabled                                                                              | R/W |
| b4  | FMS1   | Flash Operating Mode Select 1 | See the FMS0 bit.                                                                                                                                 | R/W |
| b5  | _      | Reserved                      | This bit is read as 0. The write value should be 0.                                                                                               | R/W |
| b6  | LVPE   | Low-Voltage P/E Mode Enable   | 0: Low-voltage P/E mode disabled 1: Low-voltage P/E mode enabled                                                                                  | R/W |
| b7  | FMS2   | Flash Operating Mode Select 2 | See the FMS0 bit.                                                                                                                                 | R/W |

The FPMCR register is used to set the operating mode of the flash memory.

This register is protected. Set its value using the procedure to unlock protection. For details, refer to section 31.3.2, Protection Unlock Register (FPR).

When entering discharge mode 2 or ROM P/E mode, or during either of these modes, an instruction must be executed on the RAM.

#### FMS0, FMS1, and FMS2 Bits (Flash Operating Mode Select 0 to Flash Operating Mode Select 2)

These bits are used to set the operating mode of the flash memory.

[Transition from read mode to ROM P/E mode]

Set the FMS2 bit = 0, the FMS1 bit = 1, the FMS0 bit = 1, and the RPDIS bit = 0.

Wait for ROM mode transition wait time 1 (tDIS, refer to section 32, Electrical Characteristics).

Set the FMS2 bit = 1, the FMS1 bit = 1, the FMS0 bit = 1, and the RPDIS bit = 0.

Set the FMS2 bit = 1, the FMS1 bit = 0, the FMS0 bit = 1, and the RPDIS bit = 0.

Wait for ROM mode transition wait time 2 (tMS, refer to section 32, Electrical Characteristics).

[Transition from ROM P/E mode to read mode]

Set the FMS2 bit = 1, the FMS1 bit = 1, the FMS0 bit = 1, and the RPDIS bit = 0.

Wait for ROM mode transition wait time 1 (tDIS, refer to section 32, Electrical Characteristics).

Set the FMS2 bit = 0, the FMS1 bit = 1, the FMS0 bit = 1, and the RPDIS bit = 0.

Set the FMS2 bit = 0, the FMS1 bit = 0, the FMS0 bit = 0, and the RPDIS bit = 1.

Wait for ROM mode transition wait time 2 (tMS, refer to section 32, Electrical Characteristics).

#### RPDIS Bit (ROM P/E Disable)

This bit is used to disable the execution of ROM programming/erasure with software.

#### LVPE Bit (Low-Voltage P/E Mode Enable)

Set this bit to 0 for programming/erasure in high-speed mode, and set this bit to 1 for programming/erasure in middle-speed mode.

### 31.3.5 Flash Initial Setting Register (FISR)

Address(es): 007F C0B6h



| Bit      | Symbol    | Bit Name                      | Description                                                                                                                                                                                                                                                                                  | R/W |
|----------|-----------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4 to b0 | PCKA[4:0] | Peripheral Clock Notification | These bits are used to set the frequency of the FlashIF clock (FCLK).                                                                                                                                                                                                                        | R/W |
| b5       | _         | Reserved                      | This bit is read as 0. The write value should be 0.                                                                                                                                                                                                                                          | R/W |
| b7, b6   | SAS[1:0]  | Start-Up Area Select          | <ul> <li>b7 b6</li> <li>0 x: The start-up area is selected according to the start-up area settings of the extra area.</li> <li>1 0: The start-up area is switched to the default area temporarily.</li> <li>1 1: The start-up area is switched to the alternate area temporarily.</li> </ul> | R/W |

x: Don't care

Data can be written to the FISR register in ROM P/E mode.

#### PCKA[4:0] Bits (Peripheral Clock Notification)

These bits are used to set the frequency of the FlashIF clock (FCLK) when programming/erasing the ROM.

Set the FCLK frequency in the PCKA[4:0] bits before programming/erasure. Do not change the frequency during programming/erasure of the ROM.

[When FCLK is higher than 4 MHz]

Set a rounded-up value for a non-integer frequency.

For example, set 32 MHz (PCKA[4:0] bits = 11111b) when the frequency is 31.5 MHz.

[When FCLK is 4 MH or lower]

Do not use a non-integer frequency.

Use the FCLK at a frequency of 1, 2, 3, or 4 MHz.

Note: When the PCKA[4:0] bits are set to a frequency different from the FCLK, the data in the ROM may be damaged.

Table 31.3 Example of FlashIF Clock Frequency Settings

| FlashIF Clock<br>Frequency [MHz] | PCKA[4:0] Bit<br>Setting | FlashIF Clock<br>Frequency [MHz] | PCKA[4:0] Bit<br>Setting | FlashIF Clock<br>Frequency [MHz] | PCKA[4:0] Bit<br>Setting |
|----------------------------------|--------------------------|----------------------------------|--------------------------|----------------------------------|--------------------------|
| 32                               | 11111b                   | 31                               | 11110b                   | 30                               | 11101b                   |
| 29                               | 11100b                   | 28                               | 11011b                   | 27                               | 11010b                   |
| 26                               | 11001b                   | 25                               | 11000b                   | 24                               | 10111b                   |
| 23                               | 10110b                   | 22                               | 10101b                   | 21                               | 10100b                   |
| 20                               | 10011b                   | 19                               | 10010b                   | 18                               | 10001b                   |
| 17                               | 10000b                   | 16                               | 01111b                   | 15                               | 01110b                   |
| 14                               | 01101b                   | 13                               | 01100b                   | 12                               | 01011b                   |

Table 31.3 Example of FlashIF Clock Frequency Settings

| FlashIF Clock<br>Frequency [MHz] | PCKA[4:0] Bit<br>Setting | FlashIF Clock<br>Frequency [MHz] | PCKA[4:0] Bit<br>Setting | FlashIF Clock<br>Frequency [MHz] | PCKA[4:0] Bit<br>Setting |
|----------------------------------|--------------------------|----------------------------------|--------------------------|----------------------------------|--------------------------|
| 11                               | 01010b                   | 10                               | 01001b                   | 9                                | 01000b                   |
| 8                                | 00111b                   | 7                                | 00110b                   | 6                                | 00101b                   |
| 5                                | 00100b                   | 4                                | 00011b                   | 3                                | 00010b                   |
| 2                                | 00001b                   | 1                                | 00000b                   | _                                | _                        |

#### SAS[1:0] Bits (Start-Up Area Select)

These bits are used to select the start-up area. To change the start-up area, the following three methods can be used.

(1) When selecting the start-up area according to the start-up area settings of the extra area With the SAS[1:0] bits set to 00b or 01b, the start-up area is selected according to the start-up area settings of the extra area. The settings are enabled after a reset is released.

#### (2) When switching the start-up area to the default area temporarily

When 10b is written to the SAS[1:0] bits, the start-up area is switched to the default area immediately after data is written to the register, regardless of the start-up area settings of the extra area.

When a reset is generated after this, the area is selected according to the start-up area settings of the extra area.

#### (3) When switching the start-up area to the alternative area temporarily

When 11b is written to the SAS[1:0] bits, the start-up area is switched to the alternative area, regardless of the start-up area settings of the extra area.

When a reset is generated after this, the area is selected according to the start-up area settings of the extra area.

## 31.3.6 Flash Reset Register (FRESETR)

Address(es): 007F FF89h



| Bit      | Symbol | Bit Name    | Description                                                                                              | R/W |
|----------|--------|-------------|----------------------------------------------------------------------------------------------------------|-----|
| b0       | FRESET | Flash Reset | <ul><li>0: Flash control circuit reset is released.</li><li>1: Flash control circuit is reset.</li></ul> | R/W |
| b7 to b1 | _      | Reserved    | These bits are read as 0. The write value should be 0.                                                   | R/W |

### FRESET Bit (Flash Reset)

When this bit is set to 1, registers FASR, FSARH, FSARL, FEARH, FEARL, FWBH, FWBL, FCR, and FEXCR are reset. Also, the values of registers FEAMH and FEAML are undefined. Do not access these registers during a reset. To release the reset, set this bit to 0.

Do not write to this register while executing a software command or rewriting the extra area.

## 31.3.7 Flash Area Select Register (FASR)

Address(es): 007F FF81h



| Bit      | Symbol | Bit Name          | Description                                            | R/W |
|----------|--------|-------------------|--------------------------------------------------------|-----|
| b0       | EXS    | Extra Area Select | 0: User area<br>1: Extra area                          | R/W |
| b7 to b1 | _      | Reserved          | These bits are read as 0. The write value should be 0. | R/W |

Data can be written to the FASR register in ROM P/E mode.

This register is initialized by a reset or setting the FRESETR.FRESET bit to 1.

Data cannot be written to this register while the FRESETR.FRESET bit is 1.

### **EXS Bit (Extra Area Select)**

Set this bit to 1 before issuing a software command (unique ID read, start-up area information program, or access window information program) for the extra area. Set this bit to 0 before issuing a software command (program, blank check, or block erase) for the user area.

After issuing a software command, do not change the value until changing it for issuing the next software command.

### 31.3.8 Flash Control Register (FCR)

Address(es): 007F FF85h



| Bit      | Symbol   | Bit Name                 | Description                                                                                                                          | R/W |
|----------|----------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3 to b0 | CMD[3:0] | Software Command Setting | b3 b0 0 0 0 1: Program 0 0 1 1: Blank check 0 1 0 0: Block erase 0 1 0 1: Unique ID read Settings other than above are prohibited.*1 | R/W |
| b4       | DRC      | Data Read Completion     | 0: Start data read.<br>1: Complete data read.                                                                                        | R/W |
| b5       | _        | Reserved                 | This bit is read as 0. The write value should be 0.                                                                                  | R/W |
| b6       | STOP     | Forced Processing Stop   | When this bit is set to 1, the processing being executed can be forcibly stopped.                                                    | R/W |
| b7       | OPST     | Processing Start         | Processing stops.     Processing starts.                                                                                             | R/W |

Note 1. This does not include set the FCR register to 00h when the FSTATR1.FRDY flag is 1.

Data can be written to the FCR register when in ROM P/E mode and the ROM can be programmed/erased.

This register is initialized by a reset or setting the FRESETR.FRESET bit to 1. Data cannot be written to this register while the FRESETR.FRESET bit is 1.

Note that this register cannot be initialized by the FRESETR.FRESET bit while a software command is being executed.

#### CMD[3:0] Bits (Software Command Setting)

These bits are used to set a software command (program, blank check, block erase, or unique ID read).

The function of each command is described below.

[Program]

• Write the value set in registers FWBH and FWBL to the address set in registers FSARH and FSARL.

[Blank check]

 Check whether there is data in the area from the address set in registers FSARH and FSARL to the address set in registers FEARH and FEARL. Confirm that data is not programmed in the area. This command does not guarantee whether the area remains erased.

[Block erase]

• Erase consecutive areas specified in the flash memory by the blocks. Set the beginning address of the block in registers FSARH and FSARL and the end address in registers FEARH and FEARL.

[Unique ID read]

• When executing the unique ID read after setting registers FSARH, FSARL, FEARH, and FEARL to 00h, 0850h, 00h, and 086Fh, respectively, the unique ID is stored in registers FRBH and FRBL sequentially.

#### **DRC Bit (Data Read Completion)**

This bit is used with the unique ID read command to control the state of the sequencer.

When issuing the unique ID read command with this bit set to 0, data is read from the address set in registers FSARH and FSARL, and the data is stored in registers FRBH and FRBL.

When issuing the unique ID read command with this bit set to 1 after reading data from registers FRBH and FRBL, the

sequencer ends the read cycle and enters the wait state.

When issuing the unique ID read command again with this bit set to 0, the internal address of the sequencer is incremented by 4, and the next data is read.

#### STOP Bit (Forced Processing Stop)

This bit is used to forcibly stop the processing (blank check or block erase) being executed.

After setting this bit to 1, wait until the FSTATR1.FRDY flag is 1 (processing completed) before setting the OPST bit to 0.

#### **OPST Bit (Processing Start)**

This bit is used to execute the command set in the CMD[2:0] bits.

This bit is not set to 0 again even when the processing is completed. Confirm that the FSTATR1.FRDY flag is 1 (processing completed) before setting the OPST bit to 0 again. After that, confirm that the FRDY flag is 0 before executing the next processing.

### 31.3.9 Flash Extra Area Control Register (FEXCR)

Address(es): 007F C0B7h



| Bit      | Symbol   | Bit Name                 | Description                                                                                                                         | R/W |
|----------|----------|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----|
| b2 to b0 | CMD[2:0] | Software Command Setting | b2 b0 0 0 1: Start-up area information program 0 1 0: Access window information program Settings other than above are prohibited.*1 | R/W |
| b6 to b3 | _        | Reserved                 | These bits are read as 0. The write value should be 0.                                                                              | R/W |
| b7       | OPST     | Processing Start         | Processing stops.     Processing starts.                                                                                            | R/W |

Note 1. This does not include set the FEXCR register to 00h when the FSTATR1.EXRDY flag is 1.

Data can be written to the FEXCR register when in ROM P/E mode and the ROM can be programmed/erased.

This register is initialized by a reset or setting the FRESETR.FRESET bit to 1. Data cannot be written to this register while the FRESETR.FRESET bit is 1.

Note that this register cannot be initialized by the FRESETR.FRESET bit while a software command is being executed.

#### CMD[2:0] Bits (Software Command Setting)

These bits are used to set a software command (start-up area information program or access window information program).

The details of each command are described below.

[Start-up area information program]

This command is used to switch the start-up area used for start-up program protection.

- When setting the start-up area to the default area
   Set registers FWBH and FWBL to FFFFh, and execute this command.
- When setting the start-up area to the alternative area

  Set the FWBH register to FFFFh, set the FWBL register to FEFFh, and execute this command.



When registers FWBH and FWBL are set to values other than the above, do not execute the start-up area information program.

[Access window information program]

This command is used to set the access window used for area protection.

Set the access window in block units.

Specify the access window start address, which is the beginning address of the access window in the FWBL register, specify the access window end address, which is the next address of the last address of the access window in the FWBH register, and issue this command. Set bit 19 to bit 10 of the address for programming/erasure in each register. If the same value is set as the start address and end address, all areas can be accessed. Do not set the start address to a value larger than the value of the end address.

#### **OPST Bit (Processing Start)**

This bit is used to execute the command set in the CMD[2:0] bits.

This bit is not set to 0 again even when the processing is completed. Confirm that the FSTATR1.EXRDY flag is 1 (processing completed) before setting the OPST bit to 0 again. After that, confirm that the FSTATR1.EXRDY flag is 0 before executing the next processing.

Writing to the extra area is started by writing 1 to the OPST bit. Do not write to the CMD[2:0] bits while a software command is being executed.



## 31.3.10 Flash Processing Start Address Register H (FSARH)

Address(es): 007F FF84h



The FSARH register is used to set the target processing address or the start address of the target processing range in the flash memory when a software command is executed.

Set bit 19 to bit 16 of the flash memory address for programming/erasure in this register.

Data can be written to this register in ROM P/E mode.

This register is initialized by a reset or setting the FRESETR.FRESET bit to 1. Data cannot be written to this register while the FRESETR.FRESET bit is 1.

If this register is read while executing a software command set by the FEXCR register, an undefined value is read. Refer to Figure 31.1 for details on the addresses of the flash memory.

## 31.3.11 Flash Processing Start Address Register L (FSARL)

Address(es): 007F FF82h



The FSARL register is used to set the target processing address or the start address of the target processing range in the flash memory when a software command is executed.

Set bit 15 to bit 0 of the flash memory address for programming/erasure in this register.

To set the ROM area, set bit 1 and bit 0 to 00b.

Data can be written to this register in ROM P/E mode.

This register is initialized by a reset or setting the FRESETR.FRESET bit to 1. Data cannot be written to this register while the FRESETR.FRESET bit is 1.

If this register is read while executing a software command set by the FEXCR register, an undefined value is read. Refer to Figure 31.1 for details on the addresses of the flash memory.

## 31.3.12 Flash Processing End Address Register H (FEARH)

Address(es): 007F FF88h



The FEARH register is used to set the end address of the target processing range in the flash memory when a software command is executed.

Set bit 19 to bit 16 of the flash memory address for programming/erasure in this register.

Data can be written to this register in ROM P/E mode.

This register is initialized by a reset or setting the FRESETR.FRESET bit to 1. Data cannot be written to this register while the FRESETR.FRESET bit is 1.

If this register is read while executing a software command set by the FEXCR register, an undefined value is read. Refer to Figure 31.1 for details on the addresses of the flash memory.

## 31.3.13 Flash Processing End Address Register L (FEARL)

Address(es): 007F FF86h



The FEARH register is used to set the end address of the target range for processing when a software command is executed.

Set bit 15 to bit 0 of the flash memory address for programming/erasure in this register.

When setting the ROM area, set bit 1 and bit 0 to 00b.

Data can be written to this register in ROM P/E mode.

This register is initialized by a reset or setting the FRESETR.FRESET bit to 1. Data cannot be written to this register while the FRESETR.FRESET bit is 1.

If this register is read while executing a software command set by the FEXCR register, an undefined value is read. Refer to Figure 31.1 for details on the addresses of the flash memory.

### 31.3.14 Flash Read Buffer Register H (FRBH)

Address(es): 007F C0C4h



This register is used to store the upper 2 bytes of the 4-byte data (part of the unique ID) that is read from the extra area when unique ID read is executed.

## 31.3.15 Flash Read Buffer Register L (FRBL)

Address(es): 007F C0C2h



This register is used to store the lower 2 bytes of the 4-byte data (part of the unique ID) that is read from the extra area when unique ID read is executed.

## 31.3.16 Flash Write Buffer Register H (FWBH)

Address(es): 007F FF8Eh



This register is used to set the high-order 16 bits of the data for programming the ROM.

Data can be written to this register in ROM P/E mode.

This register is initialized by a reset or setting the FRESETR.FRESET bit to 1. Data cannot be written to this register while the FRESETR.FRESET bit is 1.

The value read from this register is undefined while a software command is being executed.

If this register is read while executing a software command set by the FEXCR register, an undefined value is read.

## 31.3.17 Flash Write Buffer Register L (FWBL)

Address(es): 007F FF8Ch



This register is used to set the low-order 16 bits of the data for programming the ROM.

Data can be written to this register in ROM P/E mode.

This register is initialized by a reset or setting the FRESETR.FRESET bit to 1. Data cannot be written to this register while the FRESETR.FRESET bit is 1.

If this register is read while executing a software command set by the FEXCR register, an undefined value is read.

## 31.3.18 Flash Status Register 0 (FSTATR0)

Address(es): 007F FF8Ah



| Bit    | Symbol   | Bit Name                                 | Description                                                                                                                                    | R/W |
|--------|----------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0     | ERERR    | Erase Error Flag                         | 0: Erasure terminates normally. 1: An error occurs during erasure.                                                                             | R   |
| b1     | PRGERR   | Program Error Flag                       | Programming terminates normally.     An error occurs during programming.                                                                       | R   |
| b2     | _        | Reserved                                 | The read value is undefined.                                                                                                                   | R   |
| b3     | BCERR    | Blank Check Error Flag                   | Blank checking terminates normally.     An error occurs during blank checking.                                                                 | R   |
| b4     | ILGLERR  | Illegal Command Error Flag               | O: No illegal software command or illegal access is detected.  1: An illegal command or illegal access is detected.                            | R   |
| b5     | EILGLERR | Extra Area Illegal Command Error<br>Flag | O: No illegal command or illegal access to the extra area is detected.  1: An illegal command or illegal access to the extra area is detected. | R   |
| b7, b6 | _        | Reserved                                 | The read value is undefined.                                                                                                                   | R   |

This register is a status register used to confirm the result of executing a software command. Each error flag is set to 0 when the next software command is executed.

### **ERERR Flag (Erase Error Flag)**

This flag indicates the result of the erase processing for the ROM.

[Setting condition]

• An error occurs during erasure.

[Clearing condition]

The next software command is executed.
 The value read from this flag is undefined when the FCR.STOP bit is set to 1 (processing is forcibly stopped) during erasure.

#### PRGERR Flag (Program Error Flag)

This flag indicates the result of the program processing for the ROM. [Setting condition]

• An error occurs during programming.

[Clearing condition]

• The next software command is executed.

### **BCERR Flag (Blank Check Error Flag)**

This flag indicates the result of the blank check processing for the ROM. [Setting condition]

• An error occurs during blank checking.

#### [Clearing condition]

• The next software command is executed.

The value read from this flag is undefined when the FCR.STOP bit is set to 1 (processing is forcibly stopped) during blank checking.

#### **ILGLERR Flag (Illegal Command Error Flag)**

This flag indicates the result of executing a software command.

[Setting conditions]

- Programming/erasure is executed to an area other than the access window range.
- A blank check or block erase command is executed when the set value of registers FSARH and FSARL is larger than the set value of registers FEARH and FEARL.
- Program and block erase commands are executed when the FASR.EXS bit is 1.

[Clearing condition]

• The next software command is executed.

### **EILGLERR Flag (Extra Area Illegal Command Error Flag)**

This flag indicates the result of executing a software command for the extra area.

[Setting condition]

• A software command for the extra area is executed when the FASR.EXS bit is 0.

[Clearing condition]

• The next software command is executed.

## 31.3.19 Flash Status Register 1 (FSTATR1)

Address(es): 007F FF8Bh



| Bit      | Symbol | Bit Name                                                                                                                       | Description                                                                                                    | R/W |
|----------|--------|--------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-----|
| b0       | _      | Reserved                                                                                                                       | This bit is read as 0.                                                                                         | R   |
| b1       | DRRDY  | Data Read Ready Flag                                                                                                           | 0: No valid data in registers FRBH and FRBL 1: Valid data in registers FRBH and FRBL                           | R   |
| b2       | _      | Reserved                                                                                                                       | This bit is read as 1.                                                                                         | R   |
| b5 to b3 | _      | Reserved                                                                                                                       | These bits are read as 0.                                                                                      | R   |
| b6       | FRDY   | Flash Ready Flag  0: Other than below 1: 00h can be written to the FCR register (processing to complete the software command). |                                                                                                                | R   |
| b7       | EXRDY  | Extra Area Ready Flag                                                                                                          | O: Other than below 1: 00h can be written to the FEXCR register (processing to complete the software command). | R   |

This register is a status register used to confirm the result of executing a software command. Each flag is set to 0 when the next software command is executed.

#### **DRRDY Flag (Data Read Ready Flag)**

This flag is used to check if the valid read data is stored in registers FRBH and FRBL.

When the sequencer stores data read from the flash memory to registers FRBH and FRBL, the DRRDY flag becomes 1. When issuing the unique ID command with the FCR.DRC bit set to 1, the sequencer ends the read cycle, and the DRRDY flag becomes 0.

Note that, even if issuing the unique ID command with the FCR.DRC bit set to 0 after reading data from the address set in registers FEARH and FEARL, the DRRDY flag does not become 1, but the FRDY flag becomes 1.

#### FRDY Flag (Flash Ready Flag)

This flag is used to confirm whether a software command is executed.

This flag becomes 1 when processing of the executed software command or the forced stop processing is completed, and this flag becomes 0 when setting the FCR.OPST bit to 0.

Also, an interrupt (FRDYI) is generated when this flag becomes 1.

#### **EXRDY Flag (Extra Area Ready Flag)**

This flag is used to confirm whether a software command for the extra area is executed.

This flag is set to 1 when processing of the executed software command is completed, and 0 when the FEXCR.OPST bit is set to 0.

Also, an interrupt (FRDYI) is generated when this flag becomes 1.

## 31.3.20 Flash Error Address Monitor Register H (FEAMH)

Address(es): 007F C0BAh



This register is used to check the address where the error has occurred if an error occurs during processing of a software command. This register stores bit 19 to bit 16 of the address where the error has occurred for the program command or blank check command, or it stores bit 19 to bit 16 of the beginning address of the area where the error has occurred for the block erase command.

Since this register value becomes undefined if setting the FRESETR.FRESET bit to 1, read the value before error processing.

If the software command terminates normally, this register stores bit 19 to bit 16 of the end address at execution of the command.

Refer to Figure 31.1 for details on the addresses of the flash memory.

## 31.3.21 Flash Error Address Monitor Register L (FEAML)

Address(es): 007F C0B8h



This register is used to check the address where the error has occurred if an error occurs during processing of a software command. This register stores bit 15 to bit 0 of the address where the error has occurred for the program command or blank check command, or it stores bit 15 to bit 0 of the beginning address of the area where the error has occurred for the block erase command.

Since this register value becomes undefined if setting the FRESETR.FRESET bit to 1, read the value before error processing.

When the software command is normally completed, this register stores bit 15 to bit 0 of the last address at execution of the command.

When executing a software command for the ROM or the unique ID read command, low-order 2 bits become 00b. Refer to Figure 31.1 for details on the addresses of the flash memory.

## 31.3.22 Flash Start-Up Setting Monitor Register (FSCMR)

Address(es): 007F C0B0h



| Bit       | Symbol | Bit Name                           | Description                                                                                   | R/W |
|-----------|--------|------------------------------------|-----------------------------------------------------------------------------------------------|-----|
| b7 to b0  | _      | Reserved                           | These bits are read as 0.                                                                     | R   |
| b8        | SASMF  | Start-Up Area Setting Monitor Flag | Setting to start up using the alternative area     Setting to start up using the default area | R   |
| b14 to b9 | _      | Reserved                           | These bits are read as 1. Writing to these bits has no effect.                                | R   |
| b15       | _      | Reserved                           | This bit is read as 0. Writing to this bit has no effect.                                     | R   |

Note 1. The value of the blank product is 1. It is set to the same value set in bit 8 in the FWBL register after the start-up area information program command is executed.

### **SASMF Flag (Start-Up Area Setting Monitor Flag)**

This flag is used to confirm the settings of the start-up area.

When this flag is 0, the user program is set to start up using the alternative area.

When this flag is 1, the user program is set to start up using the default area.

## 31.3.23 Flash Access Window Start Address Monitor Register (FAWSMR)

Address(es): 007F C0B2h



Note 1. The value of the blank product is 1. It is set to the same value set in bit 9 to bit 0 the FWBL register after the access window information program command is executed.

This register is used to confirm the set value of the access window start address used for area protection.

## 31.3.24 Flash Access Window End Address Monitor Register (FAWEMR)

Address(es): 007F C0B4h



Note 1. The value of the blank product is 1. It is set to the same value set in bit 9 to bit 0 in the FWBH register after the access window information program command is executed.

This register is used to confirm the set value of the access window end address used for area protection.

## 31.3.25 Unique ID Register n (UIDRn) (n = 0 to 31)

Address(es): 0850h to 086Fh (extra area)



The UIDRn register stores a 32-byte ID code (unique ID) for identifying the individual MCU.

The unique ID is stored in the extra area of the flash memory and cannot be rewritten by the user. Use the unique ID read command to read the register value.

## 31.4 Start-Up Program Protection

When rewriting the start-up program\*<sup>1</sup> by self-programming, if the rewrite operation is interrupted due to temporary blackout, the start-up program may not be successfully programmed and the user program may not start properly. This problem can be avoided by rewriting the start-up program without erasing the existing start-up program using the start-up program protection. This function is available in products with a 32-Kbyte or larger ROM.

Figure 31.2 shows the Overview of the Start-Up Program Protection. In this figure, the default area indicates block 0 to block 15, and the alternate area indicates block 16 to block 31.

Note 1. Program to perform operation to start the user program. It includes the fixed vector table.



Figure 31.2 Overview of the Start-Up Program Protection

### 31.5 Area Protection

Area protection enables rewriting only the selected blocks (access window) in the user area and disables rewriting the other blocks during self-programming.

Specify the start address and end address to set the access window. While the access window can be set in boot mode or by self-programming, area protection is enabled only during self-programming in single-chip mode.

Figure 31.3 shows the Area Protection Overview (When Blocks 4 to 6 are Set as the Access Window in Products with 128-Kbyte ROM).



Figure 31.3 Area Protection Overview (When Blocks 4 to 6 are Set as the Access Window in Products with 128-Kbyte ROM)

## 31.6 Programming and Erasure

The ROM can be programmed and erased by changing the mode of the dedicated sequencer for programming and erasure, and by issuing commands for programming and erasure.

The mode transitions and commands required to program or erase the ROM are described below. The descriptions apply in common to boot mode and single-chip mode.

## 31.6.1 Sequencer Modes

The sequencer has two modes. Transitions between modes are caused by writing to the FENTRYR register and setting the FPMCR register. Figure 31.4 is a diagram of mode transitions of the flash memory.



Figure 31.4 Mode Transitions of the Flash Memory

#### 31.6.1.1 Read Mode

Read mode is for high-speed reading of the ROM. Reading from a ROM address for reading can be accomplished in one ICLK clock.

### (1) ROM Read Mode

In this mode, both the ROM is in read mode. The sequencer enters this mode from P/E mode when setting the FPMCR register to 08h and setting the FENTRYR.FENTRY0 bit to 0.

#### 31.6.1.2 P/E Mode

The P/E mode is for programming and erasure of the ROM.

#### (1) ROM P/E Mode

In this mode, the ROM is in P/E mode. The sequencer enters this mode when setting the FENTRYR.FENTRY0 bit to 1 and setting the FPMCR register 82h or C2h.

### 31.6.2 Mode Transitions

#### 31.6.2.1 Transition from Read Mode to P/E Mode

Switching to ROM P/E mode is required before executing a software command for the ROM. Figure 31.5 shows the Procedure for Transition from ROM Read Mode to ROM P/E Mode.



Figure 31.5 Procedure for Transition from ROM Read Mode to ROM P/E Mode

### 31.6.2.2 Transition from P/E Mode to Read Mode

High-speed reading of the ROM requires switching to ROM read mode.

Figure 31.6 shows the Procedure for Transition from ROM P/E Mode to ROM Read Mode.



Figure 31.6 Procedure for Transition from ROM P/E Mode to ROM Read Mode

### 31.6.3 Software Commands

Software commands consist of commands for programming and erasure and commands for programming start-up program area information and access window information. Table 31.4 lists the software commands for use with the flash memory.

Table 31.4 Software Commands

| Command                           | Function                                                                                                                                                      |  |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Program                           | ROM programming (4 bytes)                                                                                                                                     |  |
| Block erase                       | ROM erasure                                                                                                                                                   |  |
| Blank check                       | Check whether the specified area is blank.  Confirm that data is not programmed in the area. This command does not guarantee whether the area remains erased. |  |
| Start-up area information program | Rewrite the start-up area switching information used for start-up program protection.                                                                         |  |
| Access window information program | Set the access window used for area protection.                                                                                                               |  |
| Unique ID read                    | Read the unique ID in the extra area.                                                                                                                         |  |

## 31.6.4 Software Command Usage

This section describes how to use each software command, using flowcharts.

### 31.6.4.1 Program

Figure 31.7 shows the procedure to issue the program command.



Figure 31.7 Procedure to Issue the Program Command

### 31.6.4.2 Block Erase

Figure 31.8 shows the procedure to issue the block erase command.



Figure 31.8 Procedure to Issue the Block Erase Command

### 31.6.4.3 Blank Check

Figure 31.9 shows the procedure to issue the blank check command.



Figure 31.9 Procedure to Issue the Blank Check Command

## 31.6.4.4 Start-Up Area Information Program/Access Window Information Program

Figure 31.10 shows the procedure to issue the start-up area information program command and access window information program command.



Figure 31.10 Procedure to Issue the Start-Up Area Information Program Command/Access Window Information Program Command

### 31.6.4.5 Unique ID Read

Figure 31.11 shows the procedure to issue the unique ID read command.



Figure 31.11 Procedure to Issue the Unique ID Read Command

### 31.6.4.6 Forced Stop of Software Commands

Perform the procedure shown in Figure 31.12 to forcibly stop the blank check command or block erase command. When the command processing is forcibly stopped, registers FEAMH and FEAML store the address at the time of the forced stop. For blank check, the stopped processing can be continued by copying the FEAMH and FEAML register values to registers FSARH and FSARL.



Figure 31.12 Procedure for Forced Stop of Software Commands

### 31.6.5 Interrupt

When software command processing or forced stop processing is completed, an interrupt (FRDYI) is generated. When the FSTATR1.FRDY flag becomes 0 by setting the FCR.OPST bit to 0 and the FSTATR1.EXRDY flag becomes 0 by setting the FEXCR.OPST bit to 0, the next interrupt (FRDYI) can be accepted.

Clear the IRn.IR flag before setting the IERm.IEN bit of the ICU corresponding to this interrupt.

#### 31.7 Boot Mode

The SCI is used in boot mode.

Table 31.6 lists the I/O Pins Used in Boot Mode.

Table 31.5 Areas and Communication Functions Used in Boot Mode

| Boot Mode                       |                                          |                |  |  |
|---------------------------------|------------------------------------------|----------------|--|--|
| Item                            | SCI Interface                            | FINE Interface |  |  |
| Programmable and erasable areas | User area                                | User area      |  |  |
| Communication function          | SCI1 (asynchronous serial communication) | FINE           |  |  |

Table 31.6 I/O Pins Used in Boot Mode

| Pin Name | I/O    | Mode                          | Description                                                                      |
|----------|--------|-------------------------------|----------------------------------------------------------------------------------|
| MD       | Input  | Boot mode                     | Select operating mode (refer to section 3, Operating Modes).                     |
| MD/FINED | I/O    | Boot mode<br>(FINE interface) | Select operating mode and FINE data I/O                                          |
| P15/RXD1 | Input  | Boot mode<br>(SCI interface)  | Receive data through SCI1 for dedicated flash memory programmer communication*1  |
| P16/TXD1 | Output |                               | Transmit data through SCI1 for dedicated flash memory programmer communication*1 |

Note 1. When using the SCI, connect (pull up) this pin to VCC via a resistor.

### 31.7.1 Boot Mode (SCI)

The flash memory can be programmed and erased using asynchronous serial communication in boot mode (SCI). The user area can be rewritten.

When a reset is released while the MD pin is low, the MCU starts in boot mode (SCI).

Contact the manufacturer for details on the serial programmer (SCI programmer).

## 31.7.1.1 System Configuration in Boot Mode (SCI)

SCI1 is used to communicate with the serial programmer in boot mode (SCI).

Prepare tools for transmitting/receiving control commands and status via asynchronous serial communication, and data for programming in the serial programmer. Figure 31.13 shows the Example of Pin Connections in Boot Mode (SCI). Table 31.7 lists Pin Handling in Boot Mode (SCI).

The examples of pin connections shown in this section are simplified circuits. Operations are not guaranteed in all systems.



Figure 31.13 Example of Pin Connections in Boot Mode (SCI)

Table 31.7 Pin Handling in Boot Mode (SCI)

| Pin Name                   | Name                              | I/O    | Function                                                                                 |
|----------------------------|-----------------------------------|--------|------------------------------------------------------------------------------------------|
| VCC, VSS                   | Power supply                      | _      | Input the guaranteed voltage for program/erase to the VCC pin. Input 0 V to the VSS pin. |
| AVCC0, AVSS0               | 12-bit A/D converter power supply | _      | Connect the AVCC0 pin to the VCC pin. Connect the AVSS0 pin to the VSS pin.              |
| VCL                        | Decoupling capacitor connect pin  | _      | Connect to the VSS pin via a decoupling capacitor for stabilizing the internal voltage.  |
| XTAL, EXTAL                | Main clock I/O pin                | I/O    | Input high or low, or leave open.                                                        |
| XCIN, XCOUT                | Sub-clock I/O pin                 | I/O    | Input high or low, or leave open.                                                        |
| MD                         | Operating mode control            | Input  | Connect the VSS pin, or connect the VSS pin via a resistor (pull down).                  |
| RES#                       | Reset input                       | Input  | Reset pin. Connect to the reset circuit.                                                 |
| P15/RXD1                   | Data input RXD                    | Input  | Input pin for serial data                                                                |
| P16/TXD1                   | Data output TXD                   | Output | Output pin for serial data                                                               |
| Ports other than the above | Input port                        | Input  | Input high or low, or leave the pin open.                                                |

As shown in Figure 31.14, set the format to 8-bit data, 1 stop bit, no parity, and LSB first to communicate with the serial programmer.



Figure 31.14 Communication Format

Initial communication with the programmer is performed at 9,600 bps or 19,200 bps. The communication bit rate can be changed after the MCU is connected with the programmer.

Table 31.8 lists the maximum communication bit rates for communication in boot mode (SCI).

**Table 31.8** Conditions for Communication

| Operating Voltage                     | Maximum Communication Bit Rate |
|---------------------------------------|--------------------------------|
| 1.8 V or higher, and lower than 3.0 V | 500 kbps                       |
| 3.0 V or higher, and 3.6 V or lower   | 2 Mbps                         |

# 31.7.1.2 Starting Up in Boot Mode (SCI)

according to the range described in section 32.3.2, Reset Timing.

To start up in boot mode (SCI), release the reset (drive the RES# pin high from low) while the MD pin is low. After starting up in boot mode (SCI), wait at least 400 ms until communication is enabled in boot mode (SCI). As shown in Figure 31.15, keep the signal of each pin unchanged for 400 ms after the reset is released. Use resets



Figure 31.15 Wait Time until Communication Becomes Possible in Boot Mode (SCI)

## 31.7.2 Boot Mode (FINE Interface)

The flash memory can be programmed and erased using the FINE in boot mode (FINE interface). The user area can be rewritten.

Contact the manufacturer for details on the serial programmer.

## 31.7.2.1 Operating Conditions in Boot Mode (FINE Interface)

FINE is used to communicate with the serial programmer in boot mode (FINE Interface).

Figure 31.16 shows an Example of Pin Connections in Boot Mode (FINE Interface). Table 31.9 lists Pin Handling in Boot Mode (FINE Interface).

The example of pin connections shown in Figure 31.16 is a simplified circuit. Operations are not guaranteed in all systems.



Figure 31.16 Example of Pin Connections in Boot Mode (FINE Interface)

Table 31.9 Pin Handling in Boot Mode (FINE Interface)

| Pin Name | Name                             | I/O   | Function                                                                                |
|----------|----------------------------------|-------|-----------------------------------------------------------------------------------------|
| VCC, VSS | Power supply                     | _     | Input 1.8 V or higher to the VCC pin. Input 0 V to the VSS pin.                         |
| VCL      | Decoupling capacitor connect pin | _     | Connect to the VSS pin via a decoupling capacitor for stabilizing the internal voltage. |
| MD       | Operating mode control/data I/O  | Input | Connect the VCC pin via a resistor (pull up).                                           |
| RES#     | Reset input                      | Input | Reset pin. Connect to the reset circuit.                                                |

### 31.8 Flash Memory Access Disable Function

The flash memory access disable function disables reading and programming of the flash memory. The boot mode ID code protection is for boot mode, and the on-chip debugging emulator ID code protection is for the on-chip debugging emulator. Details are below.

#### 31.8.1 ID Code Protection

There are two types of ID code protection: Boot mode ID code protection for connecting the serial programmer and on-chip debugging emulator ID code protection is for connecting the on-chip debugging emulator. The same ID codes are used for both functions, but operations differ.

ID codes consist of the control code and ID code 1 to ID code 15. Set ID codes to four 32-bit data in 32-bit units. Figure 31.17 shows the ID Code Configuration.

| -          | 31 24        | 23 16      | 15 8       | 7 0        |
|------------|--------------|------------|------------|------------|
| FFFF FFA0h | Control code | ID code 1  | ID code 2  | ID code 3  |
| FFFF FFA4h | ID code 4    | ID code 5  | ID code 6  | ID code 7  |
| FFFF FFA8h | ID code 8    | ID code 9  | ID code 10 | ID code 11 |
| FFFF FFACh | ID code 12   | ID code 13 | ID code 14 | ID code 15 |

Figure 31.17 ID Code Configuration

The following shows a program example for setting ID codes

This is an example when setting the control code to 45h and setting ID codes to 01h, 02h, 03h, 04h, 05h, 06h, 07h, 08h, 09h, 0Ah, 0Bh, 0Ch, 0Dh, 0Eh, and 0Fh (from the ID code 1 field to the ID code 15 field).

#### C language:

#pragma address ID\_CODE = 0xFFFFFA0 const unsigned long ID\_CODE [4] = {0x45010203, 0x04050607,0x08090A0B, 0x0C0D0E0F};

#### Assembly language:

.SECTION ID\_CODE,CODE

.ORG 0FFFFFA0h

.LWORD 45010203h

.LWORD 04050607h

.LWORD 08090A0Bh

.LWORD 0C0D0E0Fh

#### 31.8.1.1 Boot Mode ID Code Protection

Boot mode ID code protection disables reading and programming of the user area.

When the control code indicates that the boot mode ID code protection is disabled while the user area is blank, the user area can be read and programmed.

When the control code indicates that the boot mode ID code protection is disabled while the user area have data, the MCU enters the erase ready state so the user area can be erased. After all blocks in the user area is erased in the erase ready state, the user area can be read and programmed.

When the control code indicates that boot mode ID code protection is enabled, the MCU compares ID codes sent from the programmer with the control code and ID code 1 to ID code 15 in the user area. According to the comparison result, reading and programming the user area is disabled.

#### (1) Control Code

The control code determines whether protection is enabled or disabled and the method of authentication with the programmer. Table 31.10 lists the protection specifications and Figure 31.18 shows the protection authentication flow.

Table 31.10 Boot Mode ID Code Protection Specifications

| ID Code         |                                                                                  |            | ID Code                               |                         |                                                                                                            |
|-----------------|----------------------------------------------------------------------------------|------------|---------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------|
| Control<br>Code | ID Code 1 to<br>ID Code 15                                                       | Protection | Matching<br>Result                    | Content of User<br>Area | Operation                                                                                                  |
| 45h             | Any desired value                                                                | Enabled    | Matched                               | _                       | Exit the boot mode ID code authentication state and enter the program/erase state.                         |
|                 |                                                                                  |            | Not matched                           | _                       | Continue the boot mode ID code authentication state.                                                       |
|                 |                                                                                  |            | Not matched three times consecutively | Not blank               | Enter the erase ready state for erasing the user area.                                                     |
| 52h             | 50h, 72h, 6Fh, 74h,<br>65h, 63h, 74h, FFh,<br>, and FFh<br>(8 bytes are all FFh) | Enabled    | N/A                                   | _                       | Disable reading or rewriting of the flash memory, regardless of the codes sent from the serial programmer. |
|                 | Other than above                                                                 |            | Matched                               | _                       | Exit the boot mode ID code authentication state and enter the program/erase state.                         |
|                 |                                                                                  |            | Not matched                           | _                       | Continue the boot mode ID code authentication state.                                                       |
| Other than      | Any desired value                                                                | Disabled   | N/A                                   | Blank                   | Enter the program/erase state.                                                                             |
| above           |                                                                                  |            |                                       | Not blank               | Enter the erase ready state for erasing the user area.                                                     |



Figure 31.18 Authentication for Boot Mode ID Code Protection

#### (2) ID Code 1 to ID Code 15

ID code 1 to ID code 15 can be set to any desired value.

## 31.8.1.2 On-Chip Debugging Emulator ID Code Protection

On-chip debugging emulator ID code protection enables or disables connection with the on-chip debugging emulator. When the on-chip debugging emulator ID code protection is disabled, connection with the on-chip debugging emulator is enabled. When 16-byte ID codes sent from the on-chip debugging emulator and ID codes in the user area match while on-chip debugging emulator ID code protection is enabled, connection with the on-chip debugging emulator is also enabled.

The ID code configuration shown in Figure 31.17 is used for the on-chip debugging emulator ID code protection. Table 31.11 lists the protection specifications.

Table 31.11 On-Chip Debugging Emulator ID Code Protection Specifications

| ID Code         |                                                           |            | ID Code            |                                                                                                                           |  |
|-----------------|-----------------------------------------------------------|------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|--|
| Control<br>Code | ID Code 1 to<br>ID Code 15                                | Protection | Matching<br>Result | Operation                                                                                                                 |  |
| FFh             | FFh,, and FFh<br>(15 bytes are all FFh)                   | Disabled   | N/A                | Enable connection with the on-chip debugging emulator.                                                                    |  |
| 52h             | 50h, 72h, 6Fh, 74h,<br>65h, 63h, and 74h +<br>any 8 bytes | Enabled    | N/A                | Disable connection with the on-chip debugging emulator, regardless of the codes sent from the on-chip debugging emulator. |  |
| Other than      | Other than above                                          | Enabled    | Matched            | Connection with the on-chip debugging emulator is enabled.                                                                |  |
| above           |                                                           |            | Not matched        | Continue the ID code wait state.                                                                                          |  |

#### 31.9 Communication Protocol

This section describes the protocol used in boot mode. When developing a serial programmer, control with this communication protocol.

## 31.9.1 State Transition in Boot Mode (SCI)

Figure 31.19 shows the Boot Mode (SCI) State Transition. Descriptions for numbers in parenthesis are on the following page.



Figure 31.19 Boot Mode (SCI) State Transition

#### (1) Bit rate automatic adjustment state

In this state, the bit rate is automatically adjusted for communication with the host.

When the bit rate adjustment is completed, the MCU sends 00h to the host. After that, when the MCU receives 55h sent from the host, the MCU sends E6h to the host, and the MCU enters the inquiry/setting host command wait state.

The host must not send data until 400 ms elapse after a reset of the MCU is released.

(2) Inquiry/setting host command wait state

In this state, the host can make inquiries for the MCU information including area configuration, size, and addresses, and select a device and bit rate.

When the host sends a program/erase state transition command, the MCU enters the boot mode ID code authentication state.

Refer to section 31.9.4, Inquiry Commands and section 31.9.5, Setting Commands for details on inquiry/setting commands.

(3) Boot mode ID code authentication state

In this state, the MCU compares ID codes in boot mode ID code protection.

When the user area is blank while boot mode ID code protection is disabled, the MCU enters the program/erase state. When the user area is not blank while boot mode ID code protection is disabled, the MCU enters the erase ready state to erase the user area. When all blocks in the user area is erased in the erase ready state, the MCU enters the program/erase state. When boot mode ID codes do not match, the MCU remains in the boot mode ID code authentication state.

Refer to section 31.8.1.1, Boot Mode ID Code Protection for details on boot mode ID code protection. Refer to section 31.9.6, ID Code Authentication Command for details on the ID code authentication command.

(4) Program/erase state

In this state, the MCU executes program/erase or read-check commands according to commands sent from the host. Refer to section 31.9.7, Program/Erase Commands for details on program/erase commands. Refer to section 31.9.8, Read-Check Commands for details on read-check commands.

## 31.9.2 Command and Response Configuration

The communication protocol is composed of a "Command" sent from the host to the MCU and a "Response" sent from the MCU to the host. Commands include 1-byte commands and multiple-byte commands. Responses include 1-byte responses, multiple-byte responses, and error responses.

A multiple-byte command and multiple-byte response have "Size" for informing the number of transmit/receive data bytes and "SUM" for detecting communication errors.

"Size" indicates the number of transmit/receive data bytes excluding Command code (the first byte), Size, SUM. "SUM" indicates byte data that is calculated so the total bytes of Command or Response becomes 00h.

The flash memory addresses for reading are used as the following addresses: the program address specified in the program command, the block start address specified in the block erase command, the AW start and end addresses specified in the access window information program command, and the AW start and end addresses received in the access window read command.

For details on the flash memory addresses for reading, see Figure 31.1.

When the host sends an undefined command, the MCU sends a command error as a response. The contents of the response is shown below. "Command code" in the error response stores the first byte of the command sent from the MCU.



## 31.9.3 Boot Mode Status Inquiry

This command is used to check the current state and the previous error of the boot program. The MCU returns a code from Table 31.12 and Table 31.13 as the current state and the previous error.

The boot mode status inquiry command can be used in the inquiry/setting host command wait state and program/erase state.



Size (1 byte): Total bytes of "State" and "Error" (the value is always 02h)

State (1 byte): MCU state (see Table 31.12)

Error (1 byte): Information about the error occurred in the MCU (see Table 31.13)

SUM (1 byte): Value that is calculated so the sum of response data is 00h

Table 31.12 Information Regarding the States

| Code    | State*1                                 | Description                                       |
|---------|-----------------------------------------|---------------------------------------------------|
| 11h     | Inquiry/setting host command wait state | Device selection wait state                       |
| 12h/13h |                                         | Clock mode selection wait state                   |
| 1Fh     |                                         | Program/erase state transition command wait state |
| 3Fh     | Program/erase state                     | Program/erase host command wait state             |
| 4Fh     | <u> </u>                                | Program wait state                                |
| 5Fh     | <u> </u>                                | Erase wait state                                  |

Note 1. Refer to Figure 31.19 for details on the states.

Table 31.13 Error Information

| Code | Description                         |
|------|-------------------------------------|
| 00h  | No error                            |
| 11h  | SUM error                           |
| 21h  | Device code error                   |
| 24h  | Bit rate selection error            |
| 29h  | Block address error                 |
| 2Ah  | Address error                       |
| 2Bh  | Data length error                   |
| 51h  | Erase error                         |
| 52h  | Not blank                           |
| 53h  | Program error                       |
| 80h  | Command error                       |
| FFh  | Bit rate automatic adjustment error |

## 31.9.4 Inquiry Commands

Inquiry commands are used to obtain necessary information for sending setting commands, program/erase commands, and read-check commands. Table 31.14 lists the inquiry commands. These commands can only be used in the inquiry/setting host command wait state.

Table 31.14 Inquiry Commands

| Command                        | Description                                                                               |
|--------------------------------|-------------------------------------------------------------------------------------------|
| Supported device inquiry       | Inquiry for the device code and series name                                               |
| Data area availability inquiry | Inquiry for the availability of the data area                                             |
| User area information inquiry  | Inquiry for the number of user areas, and the start and end addresses of the user area    |
| Block information inquiry      | Inquiry for the start address of the user areas, the block size, and the number of blocks |

## 31.9.4.1 Supported Device Inquiry

When the host sends this command, the MCU sends information about a device for little endian data and a device for big endian data in this order.



Size (1 byte): Total bytes of Number of Devices, Characters, Device code, and Series name Number of devices (1 byte): Number of endian types of program data (the value is always 02h) Number of characters (1 byte): Number of characters for the device code and device name Device code (4 bytes): Identification code indicating the endian of program data Series name (n bytes): ASCII code of the series name of the supported device SUM (1 byte): Value that is calculated so the sum of response data is 00h

## 31.9.4.2 Data Area Availability Inquiry

When the host sends this command, the MCU sends data indicating that the data area is not available and area protection can be used.



Size (1 byte): Number of characters of Availability (the value is always 01h) Availability (1 byte): Availability of the data area (the value is always 18h)

18h represents the data area is not available and area protection can be used.

SUM (1 byte): Value that is calculated so the sum of response data is 00h (the value is always ADh)

## 31.9.4.3 User Area Information Inquiry

When the host sends this command, the MCU sends the number of user areas and addresses.



Size (1 byte): Total bytes of Number of areas, Area start address, and Area end address (the value is always 09h)

Number of areas (1 byte): Number of user areas (the value is always 01h)

Area start address (4 bytes): Start address of the user area Area end address (4 bytes): End address of the user area

SUM (1 byte): Value that is calculated so the sum of the response data is 00h

## 31.9.4.4 Block Information Inquiry

When the host sends this command, the MCU sends the start address, the size of one block, and the number of blocks in the user area.



Size (2 bytes): Total bytes of data from DDh to Number of blocks of the user area (the value is always 00 19h)

Start address of the user area (4 bytes): Start address of the user area

Block size of one block for the user area (4 bytes): Memory size of one block (the value is always 00 00 04 00h)

Number of blocks of the user area (4 bytes): Number of blocks in the user area

Dummy data (12 bytes): Dummy data

SUM (1 byte): Value that is calculated so the sum of response data is 00h

### 31.9.5 Setting Commands

Setting commands are used to configure the settings necessary to execute program/erase commands in the MCU. Table 31.15 lists Setting Commands. These commands can be used only in the inquiry/setting host command wait state.

Table 31.15 Setting Commands

| Command                        | Function                               |
|--------------------------------|----------------------------------------|
| Device select                  | Select a device code.                  |
| Operating frequency select     | Change the bit rate for communication. |
| Program/erase state transition | Enter the erase ready state.           |

### 31.9.5.1 Device Select

To send a device code from the host, select a device code in the response to the support device inquiry command, and send it using the device select command. Select the device code corresponding to the endian of program data. When the device is supported, the MCU sends a response. When the device is not supported or the received command is invalid, the MCU sends an error response.

| Command | 10h | Size | Device code | SUM |
|---------|-----|------|-------------|-----|
|         |     |      |             |     |

Size (1 byte): Number of characters of the device code (the value is always 04h)

Device code (4 bytes): Identification code indicating the device

(code in the response to the support device inquiry command)

SUM (1 byte): Value that is calculated so the sum of command data is 00h



Error (1 byte): Error code 11h: SUM error

21h: Device code error

## 31.9.5.2 Operating Frequency Select

When the host sends a command to set the bit rate, select 16 MHz input clock and a bit rate with error of less than 4%. When the settings are supported, the MCU sends a response. When the settings are not supported or the transmitted command is invalid, the MCU sends an error response.

After the host receives a response, wait for at least a 1-bit period at the old bit rate, and send communication confirmation data at the new bit rate. If the MCU successfully receives communication confirmation data, the MCU sends a response. If the MCU fails to receive the communication confirmation data, the MCU sends an error response.

| Command | 3Fh              | Size         | Bit rate     |  | Input frequency |
|---------|------------------|--------------|--------------|--|-----------------|
|         | Number of clocks | Multiplier 1 | Multiplier 2 |  | -               |
|         | SUM              |              |              |  |                 |

Size (1 byte): Total bytes of data of Bit rate, Input frequency, Number of clocks, and Multiplier (the value is always 07h) Bit rate (2 bytes): New bit rate

The value is calculated by dividing the bit rate by 100 (Example: Set 0C00h for 19,200 bps)

Input frequency (2 bytes): Input frequency of the MCU (the value is always 0640h: 16 MHz)

Number of clocks (1 byte): Types of clocks (the value is always 02h)

Multiplier 1 (1 byte): Multiplier of the input frequency for the system clock (ICLK) (the value is always 01h)

Multiplier 2 (1 byte): Multiplier of the input frequency for the peripheral module clock (PCLK) (the value is always 01h)

SUM (1 byte): Value that is calculated so the sum of command data is 00h



Error (1 byte): Error code 11h: SUM error

24h: Bit rate selection error



Error response FFh

#### • Bit rate selection error

A bit rate selection error occurs when the bit rate specified with the operating frequency select command cannot be set to a value with error of less than 4%. When the bit rate selected by the operating frequency select command is B, and the value of the SCI bit rate register (BRR) is N, the bit rate error is calculated by the following formula:

Error [%] = 
$$\left(\frac{16 \times 10^6}{\text{B} \times 64 \times 2^{-1} \times \text{N} + 1} - 1\right) \times 100$$

## 31.9.5.3 Program/Erase State Transition

When the host sends this command, the MCU determines whether boot mode ID code protection is enabled or disabled.

When boot mode ID code protection is disabled while the user area is blank, the MCU sends a response (06h) indicating that ID code protection is disabled and the MCU enters the program/erase state.

When boot mode ID code protection is disabled while the user area is not blank, the MCU sends a response (56h) indicating that ID code protection is disabled and the MCU enters the erase ready state.

When boot mode ID code protection is enabled, the MCU sends a response (16h) indicating that ID code protection is enabled.



ACK (1 byte): ACK code

06h: ID code protection is disabled. The user area is blank.\*1

56h: ID code protection is disabled.16h: ID code protection is enabled.

Note 1. Erase the block that is programmed before sending a program command.

#### 31.9.6 ID Code Authentication Command

The ID code authentication command is used to send data from the host to compare with the control code and ID code 1 to ID code 15 on the ROM when the boot mode ID code protection is enabled.

Table 31.16 lists ID code authentication command. This command can be used only in the boot mode ID code authentication state.

Table 31.16 ID Code Authentication Command

| Command       | Function                                                                                           |
|---------------|----------------------------------------------------------------------------------------------------|
| ID code check | Compare data with the control code and ID code 1 to ID code 15 using boot mode ID code protection. |

#### 31.9.6.1 ID Code Check

Send the same data as the control code and ID code 1 to ID code 15 in the user area from the host. When the control code and ID code 1 to ID code 15 match the boot mode ID codes, the MCU enters the program/erase state and sends a response (06h).

When ID codes do not match three times consecutively while the control code is 45h, the MCU enters the erase ready state and sends a response (56h). When they do not match or when the MCU fails to receive data, the MCU sends an error response.



Size (1 byte): Number of bytes of ID codes (the value is always 10h)
ID code (16 bytes): Control code (1 byte) + ID code 1 to ID code 15 (15 bytes)
SUM (1 byte): Value that is calculated so the sum of the command data is 00h



ACK (1 byte): ACK code

06h: The MCU enters the program/erase state. 56h: The MCU enters the erase ready state.



Error (1 byte): Error code 11h: SUM error

61h: ID codes do not match

### 31.9.6.2 Erase Ready

The erase ready is a part of the boot mode ID code protection to disable reading data stored in the user area when protection is disabled while the user area is not blank or when ID codes do not match three times while the control code is 45h.

Only the erase preparation command and block erase command can be accepted in the erase ready state.

Table 31.17 lists ID Code Authentication Command.

Table 31.17 Commands Used for Erase Ready

| Command           | Function                                                                   |
|-------------------|----------------------------------------------------------------------------|
| Erase preparation | Enter the erase wait state.                                                |
| Block erase       | Erase the selected block, or enter the program/erase state (end of erase). |

Note: Refer to section 31.9.7, Program/Erase Commands for details on the erase preparation command and block erase command.

# 31.9.7 Program/Erase Commands

Program/erase commands are used to program or erase the user area based on the response to inquiry commands. Table 31.18 lists commands used in the program/erase command wait state, program wait state, and erase wait state. Table 31.19 lists commands that can be accepted in each state.

When a command that cannot be accepted is received in the state listed in Table 31.19, the MCU sends a command error response.

Table 31.18 Program/Erase Commands

| Command                       | Function                                                                      |
|-------------------------------|-------------------------------------------------------------------------------|
| User area program preparation | Select the user area to program, and enter the program wait state.            |
| Program                       | Program the selected area, or enter the program erase state (end of program). |
| Erase preparation             | Enter the erase wait state.                                                   |
| Block erase                   | Erase the selected block, or enter the program erase state (end of erase).    |

Table 31.19 Acceptable Commands for Each State

| State                                 | Acceptable Command                                                   |
|---------------------------------------|----------------------------------------------------------------------|
| Program/erase host command wait state | User area program preparation command, and erase preparation command |
| Program wait state                    | Program command                                                      |
| Erase wait state                      | Block erase command                                                  |

## 31.9.7.1 User Area Program Preparation

When the host sends this command, the MCU recognizes that an instruction to prepare for the program command is issued from the host, enters the program wait state, where only the program command to the user area can be accepted, and sends a response.



## 31.9.7.2 Program

Set the program address sent from the host aligned on a 256-byte boundary. When the data length is shorter than 256 bytes, the data cannot be programmed. Fill the gaps with FFh to send.

When the program from the selected address is successfully completed, the MCU sends a response. When an error occurs during a program operation, the MCU sends an error response.

When entering program/erase host command wait state, send 50h FFh FFh FFh B4h from the host. The MCU enters the program/erase host command wait state and sends a response.



Program address (4 bytes): Address for program destination

Address aligned on the program data length

Set FFFF FFFFh for end of program

Program data (n bytes): Program data (n = 256 in boot mode, 0 for end of program)

When the program is less than 256 bytes, set FFh for the missing data.

No data for the end of program

SUM (1 byte): Value that is calculated so the sum of command data is 00h



Error (1 byte): Error code

11h: SUM error

2Ah: Address error (the address is not in the selected area.)

53h: Program error (the program cannot be written.)

### 31.9.7.3 Erase Preparation

When the host sends this command, the MCU recognizes that an instruction to prepare for the erase command is issued from the host, enters the erase wait state, where only the block erase command to the user area can be accepted, and sends a response.



#### 31.9.7.4 Block Erase

Send block start address from the host based on the response to the block information inquiry command. When the block selected in the block start address is successfully erased, the MCU sends a response. If an error occurs

FFh FFh A7h from the host. The MCU enters the program/erase host command wait state and sends a response.

When the MCU enters the program/erase host command wait state after the erase operation ends, send 59h 04h FFh FFh



during an erase operation, the MCU sends an error response.

Size (1 byte): Total bytes of Block start address (the value is always 04h)
Block start address (4 bytes): Start address of the block that is erased
Set FFFF FFFFh for end of erase

SUM (1 byte): Value that is calculated so the sum of response data is 00h



Error (1 byte): Error code

11h: SUM error

29h: Block start address error (the block start address is not correct)

51h: Erase error (the selected block cannot be erased)

#### 31.9.8 Read-Check Commands

Read-check commands are used to read or check the user area in the MCU based on the response to inquiry commands. Table 31.20 lists read-check commands used in the program/erase command wait state.

Table 31.20 Read-Check Commands

| Command                           | Function                                           |
|-----------------------------------|----------------------------------------------------|
| Memory read                       | Read data from the user area.                      |
| User area checksum                | Obtain the checksum of the entire user area.       |
| User area blank check             | Check whether data is programmed in the user area. |
| Access window information program | Set the access window.                             |
| Access window read                | Read the settings of the access window.            |

# 31.9.8.1 Memory Read

For a read start address sent from the host, set an address within the range from the area start address to the area end address received in the response to the user area information inquiry command. For a read size sent from the host, set a value so the sum of the read start address and the read size is within the range from the area start address to the area end address received in the response to the user area information inquiry command.

When the MCU performs a read successfully, the MCU sends data for the read size from the read start address. When the MCU fails to read the flash memory, the MCU sends an error response.



Size (1 byte): Total bytes for Read start address and Read size

Area (1 byte): Area that is read 01h: User area

Read start address (4 bytes): Start address of the area that is read

Read size (4 bytes): Size of data that is read (in bytes)

SUM (1 byte): Value that is calculated so the sum of response data is 00h



Read size (4 bytes): Size of Data that is read (in bytes)

Read data (n bytes): Data read from the selected address (n = read size) SUM (1 byte): Value that is calculated so the sum of response data is 00h

Error response D2h Error

Error (1 byte): Error code

11h: SUM error 2Ah: Address error

- A value other than 01h is set for the "Area" field.
- The read start address is not in the selected area.

2Bh: Size error

- The read size is set to 0000 0000h.
- The read size exceeds the area size.
- The address calculated from the read start address and read size is not in the selected area.

#### 31.9.8.2 User Area Checksum

When the host sends this command, the MCU adds data from the start address and the end address in bytes in the response to the user area information inquiry command, and sends the calculated result (checksum) as a response.



Size (1 byte): Number of bytes for checksum of the user area (the value is always 04h)

User area checksum (4 bytes): Checksum result of the user area

SUM (1 byte): Value that is calculated so the sum of response data is 00h

#### 31.9.8.3 User Area Blank Check

When the host sends this command, the MCU sends a response when there is no data in the area from the start address to the end address received in the response to the user area information inquiry command. When there is at least 1 byte of data, the MCU sends an error response.



Error (1 byte): Error code 52h: Not blank

#### 31.9.8.4 Access Window Information Program

For the access window start address sent from the host, set the block start address of the user area. For the access window end address, set the block end address of the user area.

When the specified access window settings are successfully completed, the MCU sends a response. When an error occurs during a program operation, the MCU sends an error response.

The access window settings can be overwritten because it is a part of protection.

| Command | 74h                            | 05h                                  | Access window                      |                                    |
|---------|--------------------------------|--------------------------------------|------------------------------------|------------------------------------|
|         | Access window start address LH | Access window<br>start address<br>HL | Access window<br>end address<br>LH | Access window<br>end address<br>HL |
|         | SUM                            |                                      |                                    |                                    |

Access window (1 byte): Select the access window or clear the access window settings

Set 00h to select the access window

Set FFh to clear the access window settings

Access window start address LH (1 byte): Start address of the access window (A15 to A8)

Set A15 to A8 of the block start address.

Set FFh to clear the access window settings

Access window start address HL (1 byte): Start address of the access window (A23 to A16)

Set A23 to A16 of the block start address.

Set FFh to clear the access window settings

Access window end address LH (1 byte): End address of the access window (A15 to A8)

Set A15 to A8 of the block end address. Set FFh to clear the access window settings

Access window end address HL (1 byte): End address of the access window (A23 to A16)

Set A23 to A16 of the block end address. Set FFh to clear the access window settings

SUM (1 byte): Value that is calculated so the sum of response data is 00h



Error (1 byte): Error code

11h: SUM error

2Ah: Address error (address is not in the selected area) 53h: Program error (access window cannot be set)

#### 31.9.8.5 Access Window Read

Send command 73h 01h FFh 8Dh from the host.

When the MCU successfully reads the access window settings, the MCU sends the access window start address and end address that the MCU read.

If the SUM of the received command does not match, the MCU sends an error response.

| Command  | 73h                            | 01h                                  | FFh                                | 8Dh                                |
|----------|--------------------------------|--------------------------------------|------------------------------------|------------------------------------|
|          |                                |                                      | 1                                  |                                    |
| Response | 73h                            | 05h                                  |                                    |                                    |
|          | Access window start address LH | Access window<br>start address<br>HL | Access window<br>end address<br>LH | Access window<br>end address<br>HL |
|          | FFh                            |                                      |                                    |                                    |
|          | SUM                            |                                      |                                    |                                    |

Access window start address LH (1 byte): Start address of the access window (A15 to A8) Access window start address HL (1 byte): Start address of the access window (A23 to A16) Access window end address LH (1 byte): End address of the access window (A15 to A8) Access window end address HL (1 byte): End address of the access window (A23 to A16) SUM (1 byte): Value that is calculated so the sum of response data is 00h

Error response F3h Error

Error (1 byte): Error code 11h: SUM error

## 31.9.9 Serial Programmer Operation in Boot Mode (SCI)

The following describes the procedure for the serial programmer to program/erase the user area in boot mode (SCI).

- 1. Automatically adjust the bit rate
- 2. Receive the MCU information\*1
- 3. Select the device and change the bit rate
- 4. Enter the program/erase state
- 5. Unlock boot mode ID code protection
- 6. Perform erase ready processing
- 7. Erase the user area\*2
- 8. Program the user area\*2
- 9. Check data in the user area\*2
- 10. Set the access window in the user area\*3
- 11. Reset the MCU
- Note 1. If the necessary information has been already received, step 2 can be skipped.
- Note 2. Any step from 7 to 10 can be skipped, and their order can be changed.
- Note 3. When a timeout occurs or invalid response data is received, stop the operation and perform step 11 (reset the MCU).

Refer to section 31.9.9.1, Bit Rate Automatic Adjustment Procedure to section 31.9.9.10, Set the Access Window in the User Area for details on the procedure above. Refer to section 31.9.4, Inquiry Commands, section 31.9.5, Setting Commands, section 31.9.6, ID Code Authentication Command, section 31.9.7, Program/Erase Commands, and section 31.9.8, Read-Check Commands for details on commands.

#### 31.9.9.1 Bit Rate Automatic Adjustment Procedure

The MCU measures the low width of data 00h that is sent from the serial programmer at 9,600 or 19,200 bps to automatically adjust the bit rate.



Figure 31.20 Transmit/Receive Data for Bit Rate Automatic Adjustment

After starting up in boot mode, wait for at least 400 ms and then send 00h to the MCU from the serial programmer. The programmer can send 00h to the MCU up to 30 times. When the bit rate adjustment is completed, the MCU sends 00h to the programmer. When the programmer receives 00h, send 55h to the MCU from the programmer. When the programmer fails to receive 00h, restart the MCU in boot mode, and adjust the bit rate again.

When the MCU receives 55h, the MCU sends E6h and enters the inquiry/setting command wait state. When the MCU fails to receive 55h, the MCU sends FFh. When the programmer receives FFh, restart the MCU in boot mode, and adjust the bit rate again.



Figure 31.21 Bit Rate Automatic Adjustment Procedure

## 31.9.9.2 Procedure to Receive the MCU Information

Send inquiry commands, and receive the information necessary to send setting commands, program/erase commands, and read-check commands.

- (1) Send a support device inquiry command (20h) to check which device to connect. The MCU returns the device code and series name.
- (2) Send a data area availability inquiry command (2Ah) to check the availability of data area and area protection. The MCU returns the availability of data area and area protection.
- (3) Send a user area information inquiry command (25h) to check the start and end addresses of the user area. The MCU returns the start and end addresses of the user area.
- (4) Send a block information inquiry command (26h) to check the block configuration. The MCU returns the start address, the size of one block, and the number of blocks for the user area.



Figure 31.22 Procedure to Send Inquiry Commands

## 31.9.9.3 Procedure to Select the Device and Change the Bit Rate

Set the device to connect with the programmer and change the bit rate for communication.

- (1) Send the device select command (10h) to select the device to connect with the programmer and the endian of data that is programmed. When the program data is little endian, select the same device code as that for little endian in the response to the support device inquiry command. When the program data is big endian, select the same device code as that for big endian in the response to the support device inquiry command. When the device is selected successfully, the MCU sends a response (46h). When the MCU fails to receive, the MCU sends an error response (90h).
- (2) Send the operating frequency select command (3Fh) to change the bit rate for communication. When the bit rate is set successfully, the MCU sends a response (06h). When the bit rate cannot be changed, or when the MCU fails to receive, the MCU sends an error response (BFh).
- (3) When the programmer receives a response (06h), the MCU waits for 1-bit period at the bit rate for sending the operating frequency select command, and then set the bit rate of the programmer to the changed value. After that, the MCU sends communication confirmation data (06h) at the changed bit rate. When the MCU receives the command successfully, the programmer sends a response (06h) of the communication confirmation data.



Figure 31.23 Procedure to Select the Device and Change the Bit Rate

## 31.9.9.4 Transition to the Program/Erase State

The MCU needs to enter the program/erase state to perform program/erase operations.

Send the program/erase state transition command (40h). The MCU responds according to ID codes and the state of the user area.

- (1) When boot mode ID code protection is disabled while the user area is blank, the MCU sends a response (06h). After the MCU responds, the MCU is in the program/erase state and performs operations described in section 31.9.9.7, Erase the User Area to section 31.9.9.10, Set the Access Window in the User Area. Perform an erase operation described in section 31.9.9.7, Erase the User Area before programming.
- (2) When the boot mode ID code protection is disabled while the user area is not blank, the MCU sends a response (56h). After the MCU responds, the MCU is in the erase ready wait state and performs operation described in section 31.9.9.6, Erase Ready Operation.
- (3) When the boot mode ID code protection is enabled, the MCU sends a response (16h). After the MCU responds, the MCU is in the ID code authentication wait state and performs operation described in section 31.9.9.5, Unlock Boot Mode ID Code Protection.



Figure 31.24 Procedure to Enter the Program/Erase State

#### 31.9.9.5 Unlock Boot Mode ID Code Protection

After the MCU is connected with the programmer, the boot mode ID code protection is enabled so program/read, and read-check operations cannot be performed. Disable this boot mode ID code protection.

Send the ID code check command (60h). When the MCU compares the received ID codes with ID codes in the user area and responds according to the comparison result.

- (1) When ID codes match, the MCU sends a response (06h). After the MCU responds, the MCU is in the program/erase state and performs operations described in section 31.9.9.7, Erase the User Area to section 31.9.9.10, Set the Access Window in the User Area. Data in the user area is not erased. Perform an erase operation described in section 31.9.9.7, Erase the User Area before programming.
  - When ID codes do not match, the MCU sends an error response (E0h). After the MCU responds, the MCU remains in the ID code authentication wait state.
  - If ID codes do not match consecutively while the control code is 52h, reset the MCU, and then start again from section 31.9.9.1, Bit Rate Automatic Adjustment Procedure.
- (2) If ID codes do not match three times consecutively while the control code is 45h, the MCU sends a response (56h). After the MCU responds, the MCU is in the erase ready wait state and performs operation described in section 31.9.9.6, Erase Ready Operation.



Figure 31.25 Procedure to Check ID Codes

### 31.9.9.6 Erase Ready Operation

Erase the user area in the MCU.

(1) Send the erase preparation command (48h) to place the MCU in the erase wait state. The MCU enters the erase wait state and sends a response (06h).

- (2) Send a block erase command (59h) to erase blocks in the MCU. When blocks are erased successfully, the MCU sends a response (06h). When the MCU fails to receive, the MCU sends an error response (D9h). Send block erase commands repeatedly until a block erase command has been sent for the total number of blocks. The total number of blocks is number the user area blocks that are obtained in advance using the block information inquiry command. If the operation ends before all the block erase commands are sent, a command error may occur even when a correct command is sent in the program/erase state.
- (3) Send a block erase command for end of erase (59h 04h FFh FFh FFh FFh A7h). The MCU sends a response (06h).
- (4) To confirm whether erase ready operation has ended, send a boot mode status inquiry command (4Fh). The MCU sends a response to the boot mode status inquiry command when erase ready operation has ended. If erase ready operation has not ended, the MCU sends an error response (80h 4Fh). If the programmer receives an error response, restart the MCU in boot mode, and start again from section 31.9.9.1, Bit Rate Automatic Adjustment Procedure.



Figure 31.26 Procedure to Send Commands in Erase Ready Operation

#### 31.9.9.7 Erase the User Area

Erase blocks that are programmed in the user area to program a user program.

(1) Send an erase preparation command (48h) to place the MCU in the erase wait state. The MCU enters the erase wait state and sends a response (06h).

- (2) Send a block erase command (59h). Set the block that is erased in the block start address. When the selected block is erased successfully, the MCU sends a response (06h). When the MCU fails to receive, the MCU sends an error response (D9h).
- (3) In order to place the MCU in the program/erase state, send a block erase command for end of erase (59h 04h FFh FFh FFh A7h). The MCU enters the program/erase state and sends a response (06h).



Figure 31.27 Procedure to Erase the User Area

## 31.9.9.8 Program the User Area

Program a user program in the user area.

(1) Send the user program preparation command (43h) to place the MCU in the program wait state. The MCU enters the program wait sate and sends a response (06h).

- (2) Send the program command (50h). Set the program address to an address aligned on a 256-byte boundary. Set program data in 256 bytes. When the data is programmed successfully, the MCU sends a response (06h). When the MCU fails to receive, the MCU sends an error response (D0h).
- (3) In order to place the MCU in the program/erase state, send the program command for end of program (50h FFh FFh FFh B4h). The MCU enters the program/erase state and sends a response (06h).



Figure 31.28 Procedure to Program the User Area

#### 31.9.9.9 Check Data in the User Area

Read and check, checksum, and blank check the user area to check the programmed data in the user area.

(1) The read and check operation is used to read data in the user area and compare the read data with the programmed data to check if the program operation is performed successfully. Send a memory read command (52h) to read data in the user area. Set the read area in the read address and read size. The MCU sends data for the size from the address set in the read address. If the MCU fails to receive, the MCU sends an error response (D2h).

- (2) Send the user area checksum command (4Bh) to check program data using the checksum of user area. The MCU reads data from the start address to the end address of the user area in bytes and send the read result as a response.
- (3) Send a user area blank check command (4Dh) to check if the user area has data. When there is no data in the start address to the end address of the user area, the MCU sends a response (06h). When there is at least 1 byte of data, the MCU sends a response (CDh, 52h) indicating that the selected area is not blank.



Figure 31.29 Procedure to Check Data in the User Area

#### 31.9.9.10 Set the Access Window in the User Area

Set the access window to avoid unintentionally rewriting the user area during the self-programming.

- (1) Send the access window program command (74h) to set the access window or clear the access window settings. When setting the access window, set 00h in the access window field, and set the start address and the end address of the area that can be programmed during self-programming in the access window start address and the access window end address, respectively.
  - When clearing the access window settings, set FFh in the access window, access window start address LH, access window start address HL, access window end address LH, and access window end address HL.
  - When the MCU writes the addresses, the MCU sends a response (06h). If the MCU fails to receive, the MCU sends an error response (F4h).
- (2) Send the access window read command (73h) to confirm the access window settings. The MCU sends the current access window settings. When the MCU fails to receive, the MCU sends an error response (F3h).



Figure 31.30 Procedure to Set the Access Window in the User Area

# 31.10 Rewriting by Self-Programming

#### 31.10.1 Overview

The MCU supports rewriting of the flash memory by the user program. The ROM can be rewritten by preparing a routine to rewrite the flash memory (flash rewrite routine) in the user program.



Figure 31.31 Self-Programming Overview

## 31.11 Usage Notes

(1) Access the Block Where Erase Operation is Forcibly Stopped

When forcibly stopping an erase operation, data in the block where the erase operation is aborted is undefined. To avoid malfunctions caused by reading undefined data, do not execute instructions or read data in the block where an erase operation is forcibly stopped.

(2) Processing After Forced Stop of Erase Operation

When an erase operation is forcibly stopped, issue a block erase command again to the same block.

(3) Additional Programming Disabled

The same address cannot be programmed more than once. When programming an area that has been already programmed, erase the area first.

(4) Reset during Program/Erase

If inputting a reset from the RES# pin, release the reset after reset input time of at least tRESW (refer to section 32, Electrical Characteristics) within the range of the operating voltage defined in the electrical characteristics. The IWDT reset and software reset can be used regardless of tRESW.

(5) Non-maskable Interrupt Disabled during Program/Erase

When a non-maskable interrupt (NMI pin interrupt, oscillation stop detection interrupt, IWDT underflow/refresh error, voltage monitoring 1 interrupt, or voltage monitoring 2 interrupt) occurs during a program/erase operation, the vectors are fetched from the ROM, and undefined data is read. Therefore, do not generate a non-maskable interrupt during a program/erase operation on the ROM.

(The description in (5) applies only to the ROM.)

(6) Location of Interrupt Vectors during a Program/Erase Operation

When an interrupt occurs during a program/erase operation, the vector may be fetched from the ROM. To avoid fetching the vector from the ROM, set the destination for fetching interrupt vectors to an area other than the ROM with the CPU interrupt table register (INTB).

(7) Program/Erase in Low-Speed Operating Mode

Do not program or erase the flash memory when low-speed operating mode is selected by the SOPCCR register for low-power consumption functions.

(8) Abnormal Termination during Program/Erase

When the voltage exceeds the range of the operating voltage during a program/erase operation or when a program/erase operation is not completed successfully due to a reset or prohibited actions described in (9), erase the area again.

(9) Actions Prohibited during Program/Erase

To prevent the damage to the flash memory, comply with the following instructions.

- Do not use the MCU power supply that is outside the operating voltage range.
- Do not update the value of the OPCCR.OPCM[2:0] bits.
- Do not update the value of the SOPCCR.SOPCM bit.
- Do not change the clock source select bit in the SCKCR3 register.
- Do not enable switching clock sources by setting the RSTCKCR.RSTCKEN bit when exiting sleep mode.
- Do not change the division ratio of the flash interface clock (FCLK).
- Do not place the MCU in deep sleep mode or software standby mode.
- (10) FCLK during Program/Erase

For programming/erasure by self-programming, set the frequency of the FlashIF clock (FCLK), and specify an integer FCLK frequency (MHz) in FISR.PCKA[4:0] bits. Note that when the FCLK is 4 to 32 MHz, a rounded-up value should be set for a non-integer frequency such as 12.5 MHz (i.e. 12.5 MHz should be set rounded up to 13 MHz). If the FCLK is equal to or less than 4 MHz, only 1, 2, 3, or 4 MHz can be used.



# 31.12 Usage Notes in Boot Mode

- (1) Notes on Communication Errors in Boot Mode
  When communication with the MCU cannot be performed properly, reset and start up in boot mode again.
- (2) Notes on Power Supply Voltage in Boot Mode (SCI)
  When the bit rate exceeds 500 kbps in boot mode (SCI), use a voltage that is 3.0 V or higher.
- (3) Notes on Option-Setting Memory in Boot Mode

  The settings of option function select register 0 (OFS0), option function select register 1 (OFS1), and endian select register (MDE) are disabled in boot mode.
- (4) Notes on Switching the Start-Up Area Switch the start-up area by self-programming.



#### 32. Electrical Characteristics

# 32.1 Absolute Maximum Ratings

Table 32.1 Absolute Maximum Ratings

Conditions: VSS = AVSS0 = VREFL0 = 0 V

|                                               | Item                                  | Symbol           | Value                                                                                                             | Unit |
|-----------------------------------------------|---------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------------|------|
| Power supply volta                            | age                                   | VCC              | -0.3 to +4.6                                                                                                      | V    |
| Input voltage                                 | Ports for 5 V tolerant*1              | V <sub>in</sub>  | -0.3 to +6.5                                                                                                      | V    |
|                                               | Ports P40 to P44, P46, ports PJ6, PJ7 | V <sub>in</sub>  | -0.3 to AVCC0 +0.3                                                                                                | V    |
|                                               | Ports other than above                | V <sub>in</sub>  | -0.3 to VCC +0.3                                                                                                  | V    |
| Reference power :                             | supply voltage                        | VREFH0           | -0.3 to AVCC0 +0.3                                                                                                | V    |
| Analog power sup                              | ply voltage                           | AVCC0            | -0.3 to +4.6                                                                                                      | ٧    |
| Analog input voltage  Operating temperature*2 |                                       | V <sub>AN</sub>  | -0.3 to AVCC0 + 0.3<br>(when AN000 to AN004 and<br>AN006 used)<br>-0.3 to VCC + 0.3<br>(when AN008 to AN015 used) | V    |
|                                               |                                       | T <sub>opr</sub> | -40 to +85<br>-40 to +105                                                                                         | °C   |
| Storage temperature                           |                                       | T <sub>stg</sub> | -55 to +125                                                                                                       | °C   |

Caution: Permanent damage to the MCU may result if absolute maximum ratings are exceeded.

To preclude any malfunctions due to noise interference, insert capacitors of high frequency characteristics between the VCC and VSS pins, between the AVCC0 and AVSS0 pins, and between the VREFH0 and VREFL0 pins. Place capacitors of about  $0.1~\mu F$  as close as possible to every power supply pin and use the shortest and heaviest possible traces. Also, connect capacitors as stabilization capacitance.

Connect the VCL pin to a VSS pin via a  $4.7 \,\mu\text{F}$  capacitor. The capacitor must be placed close to the pin, refer to section 32.9.1, Connecting VCL Capacitor and Bypass Capacitors.

Do not input signals or an I/O pull-up power supply to ports other than 5-V tolerant ports while the device is not powered. The current injection that results from input of such a signal or I/O pull-up may cause malfunction and the abnormal current that passes in the device at this time may cause degradation of internal elements.

If input voltage (within the specified range from -0.3 to + 6.5V) is applied to 5-V tolerant ports, it will not cause problems such as damage to the MCU.

Note 1. Ports P16, P17, PA6, and PB0 are 5 V tolerant.

Note 2. The upper limit of operating temperature is 85°C or 105°C, depending on the product. For details, refer to 1.2 List of Products.

**Table 32.2 Recommended Operating Conditions** 

| Item                         | Symbol      | Min. | Тур. | Max.  | Unit |
|------------------------------|-------------|------|------|-------|------|
| Power supply voltages        | VCC*1       | 1.8  | _    | 3.6   | V    |
|                              | VSS         | _    | 0    | _     | V    |
| Analog power supply voltages | AVCC0*1, *2 | 1.8  | _    | 3.6   | V    |
|                              | AVSS0       | _    | 0    | _     | V    |
|                              | VREFH0      | 1.8  | _    | AVCC0 | V    |
|                              | VREFL0      | _    | 0    | _     | V    |

Note 1. Supply AVCC0 simultaneously with or after supplying VCC.

Note 2. Refer to section 27.6.10, Voltage Range of Analog Power Supply Pins to determine the AVCC0 voltage.

# 32.2 DC Characteristics

Table 32.3 DC Characteristics (1)

|                                         | Item                                                                                                                                                                                                         | Symbol          | Min.        | Тур. | Max.        | Unit | Test<br>Conditions |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|------|-------------|------|--------------------|
| Schmitt trigger input voltage           | RIIC input pin (except for SMBus, 5 V tolerant)                                                                                                                                                              | V <sub>IH</sub> | VCC × 0.7   | _    | 5.8         | V    |                    |
|                                         | Ports P16, P17,<br>port PA6, port PB0 (5 V tolerant)                                                                                                                                                         |                 | VCC × 0.8   | _    | 5.8         |      |                    |
|                                         | Ports P03, P05, ports P14, P15, ports P26, P27, ports P30 to P32, P35, ports P54, P55, ports PA0, PA1, PA3, PA4, ports PB1, PB3, PB5 to PB7, ports PC0 to PC7, ports PE0 to PE7, ports PH0 to PH3, PH7, RES# |                 | VCC × 0.8   | _    | VCC + 0.3   |      |                    |
|                                         | RIIC input pin (except for SMBus)                                                                                                                                                                            | V <sub>IL</sub> | -0.3        | _    | VCC × 0.3   |      |                    |
|                                         | Other than RIIC input pin                                                                                                                                                                                    |                 | -0.3        | _    | VCC × 0.2   |      |                    |
|                                         | RIIC input pin (except for SMBus)                                                                                                                                                                            | ΔV <sub>T</sub> | VCC × 0.05  | _    | _           |      |                    |
|                                         | Other than RIIC input pin                                                                                                                                                                                    |                 | VCC × 0.1   | _    | _           |      |                    |
| Input voltage                           | MD                                                                                                                                                                                                           | V <sub>IH</sub> | VCC × 0.9   | _    | VCC + 0.3   | V    |                    |
| (except for Schmitt trigger input pins) | XTAL (external clock input)                                                                                                                                                                                  |                 | VCC × 0.8   | _    | VCC + 0.3   |      |                    |
| mggor mpar pino,                        | Ports P40 to P44, P46, ports PJ6, PJ7                                                                                                                                                                        |                 | AVCC0 × 0.7 | _    | AVCC0 + 0.3 |      |                    |
|                                         | RIIC input pin (SMBus)                                                                                                                                                                                       |                 | 2.1         | _    | VCC + 0.3   |      |                    |
|                                         | MD                                                                                                                                                                                                           | V <sub>IL</sub> | -0.3        | _    | VCC × 0.1   |      |                    |
|                                         | XTAL (external clock input)                                                                                                                                                                                  |                 | -0.3        | _    | VCC × 0.2   |      |                    |
|                                         | Ports P40 to P44, P46,<br>ports PJ6, PJ7                                                                                                                                                                     |                 | -0.3        | _    | AVCC0 × 0.3 |      |                    |
|                                         | RIIC input pin (SMBus)                                                                                                                                                                                       |                 | -0.3        |      | 0.8         |      |                    |

# Table 32.4 DC Characteristics (2)

Conditions:  $1.8 \text{ V} \le \text{VCC} < 2.7 \text{ V}, 1.8 \text{ V} \le \text{AVCC0} < 2.7 \text{ V}, \text{VSS} = \text{AVSS0} = 0 \text{ V}, \text{T}_{a} = -40 \text{ to } +105 ^{\circ}\text{C}$ 

|                                         | Item                                                                                                                                                                                                         | Symbol          | Min.        | Тур. | Max.        | Unit | Test<br>Conditions |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------------|------|-------------|------|--------------------|
| Schmitt trigger input voltage           | Ports P16, P17, port PA6, port PB0 (5 V tolerant)                                                                                                                                                            | V <sub>IH</sub> | VCC × 0.8   | _    | 5.8         | V    |                    |
|                                         | Ports P03, P05, ports P14, P15, ports P26, P27, ports P30 to P32, P35, ports P54, P55, ports PA0, PA1, PA3, PA4, ports PB1, PB3, PB5 to PB7, ports PC0 to PC7, ports PE0 to PE7, ports PH0 to PH3, PH7, RES# |                 | VCC × 0.8   | _    | VCC + 0.3   |      |                    |
|                                         | All pins                                                                                                                                                                                                     |                 | -0.3        | _    | VCC × 0.2   |      |                    |
|                                         | All pins                                                                                                                                                                                                     | $\Delta V_{T}$  | VCC × 0.01  | _    | _           |      |                    |
| Input voltage                           | MD                                                                                                                                                                                                           | V <sub>IH</sub> | VCC × 0.9   | _    | VCC + 0.3   | V    |                    |
| (except for Schmitt trigger input pins) | XTAL (external clock input)                                                                                                                                                                                  |                 | VCC × 0.8   | _    | VCC + 0.3   |      |                    |
| tilgger input pilloj                    | Ports P40 to P44, P46, ports PJ6, PJ7                                                                                                                                                                        |                 | AVCC0 × 0.7 | _    | AVCC0 + 0.3 |      |                    |
|                                         | MD                                                                                                                                                                                                           | V <sub>IL</sub> | -0.3        | _    | VCC x 0.1   |      |                    |
|                                         | XTAL (external clock input)                                                                                                                                                                                  |                 | -0.3        | _    | VCC x 0.2   |      |                    |
|                                         | Ports P40 to P44, P46,<br>ports PJ6, PJ7                                                                                                                                                                     |                 | -0.3        | _    | AVCC0 × 0.3 |      |                    |

# Table 32.5 DC Characteristics (3)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}, 1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}, \text{VSS} = \text{AVSS0} = 0 \text{ V}, \text{T}_{a} = -40 \text{ to } +105^{\circ}\text{C}$ 

|                             | Item                                              |                  | Min. | Тур. | Max. | Unit | Test Conditions                              |  |
|-----------------------------|---------------------------------------------------|------------------|------|------|------|------|----------------------------------------------|--|
| Input leakage current       | RES#, MD, port P35, port PH7                      | I <sub>in</sub>  | _    | _    | 1.0  | μA   | V <sub>in</sub> = 0 V, VCC                   |  |
| Three-state                 | Ports for 5 V tolerant                            | I <sub>TSI</sub> | _    | _    | 1.0  | μΑ   | V <sub>in</sub> = 0 V, 5.8 V                 |  |
| leakage current (off-state) | Pins other than above                             |                  | _    | _    | 1.0  |      | V <sub>in</sub> = 0 V, VCC                   |  |
| Input capacitance           | All input pins<br>(except for port P16, port P35) | C <sub>in</sub>  | _    | _    | 15   | pF   | V <sub>in</sub> = 0 mV,<br>Frequency: 1 MHz, |  |
|                             | Port P16, port P35                                | 1                | _    | _    | 30   | 1    | $T_a = 25^{\circ}C$                          |  |

#### Table 32.6 DC Characteristics (4)

Conditions: 1.8 V  $\leq$  VCC  $\leq$  3.6 V, 1.8 V  $\leq$  AVCC0  $\leq$  3.6 V, VSS = AVSS0 = 0 V,  $T_a = -40$  to +105°C

| Item                   |                                              |                | Min. | Тур. | Max. | Unit | Test Conditions       |
|------------------------|----------------------------------------------|----------------|------|------|------|------|-----------------------|
| Input pull-up resistor | All ports<br>(except for port P35, port PH7) | R <sub>U</sub> | 10   | 20   | 100  | kΩ   | V <sub>in</sub> = 0 V |

|           |                 | ı              | tem                                   |               | Symbol          | Typ<br>*4 | Max  | Unit | Test<br>Conditions |
|-----------|-----------------|----------------|---------------------------------------|---------------|-----------------|-----------|------|------|--------------------|
| Supply    | High-speed      | Normal         | No peripheral operation*2             | ICLK = 32 MHz | I <sub>CC</sub> | 3.2       | _    | mA   |                    |
| current*1 | operating mode  | operating mode |                                       | ICLK = 16 MHz |                 | 2.1       | -    |      |                    |
|           |                 | mode           |                                       | ICLK = 8 MHz  |                 | 1.5       | _    |      |                    |
|           |                 |                | All peripheral operation:             | ICLK = 32 MHz |                 | 9.6       | _    |      |                    |
|           |                 |                | Normal*3                              | ICLK = 16 MHz |                 | 5.6       | _    |      |                    |
|           |                 |                |                                       | ICLK = 8 MHz  |                 | 3.5       | _    |      |                    |
|           |                 |                | All peripheral operation:<br>Max.*3   | ICLK = 32 MHz |                 |           | 21.6 |      |                    |
|           |                 | Sleep mode     | No peripheral operation*2             | ICLK = 32 MHz |                 | 1.5       | _    |      |                    |
|           |                 |                |                                       | ICLK = 16 MHz |                 | 1.2       |      |      |                    |
|           |                 |                |                                       | ICLK = 8 MHz  |                 | 1.0       | _    |      |                    |
|           |                 |                | All peripheral operation:             | ICLK = 32 MHz |                 | 5.1       |      |      |                    |
|           |                 |                | Normal*3                              | ICLK = 16 MHz |                 | 3.1       | _    |      |                    |
|           |                 |                |                                       | ICLK = 8 MHz  |                 | 2.0       | _    | †    |                    |
|           |                 | Deep sleep     | No peripheral operation*2             | ICLK = 32 MHz |                 | 1.0       | _    |      |                    |
|           |                 | mode           |                                       | ICLK = 16 MHz |                 | 0.80      | _    |      |                    |
|           |                 |                |                                       | ICLK = 8 MHz  |                 | 0.70      | _    |      |                    |
|           |                 |                | All peripheral operation:             | ICLK = 32 MHz |                 | 3.4       | _    |      |                    |
|           |                 | Normal*3       | ICLK = 16 MHz                         |               | 2.2             | _         |      |      |                    |
|           |                 |                |                                       | ICLK = 8 MHz  |                 | 1.5       | _    |      |                    |
|           | Middle-speed    | Normal         | operating                             | ICLK = 12 MHz | I <sub>CC</sub> | 1.7       | _    | mA   | -                  |
|           | operating modes | operating      |                                       | ICLK = 8 MHz  |                 | 1.3       | _    |      |                    |
|           |                 | mode           |                                       | ICLK = 1 MHz  |                 | 0.72      | _    |      |                    |
|           |                 |                | All peripheral operation:<br>Normal*6 | ICLK = 12 MHz | 1               | 4.2       | _    | -    |                    |
|           |                 |                |                                       | ICLK = 8 MHz  |                 | 3.3       |      |      |                    |
|           |                 |                |                                       | ICLK = 1 MHz  |                 | 1.2       | _    |      |                    |
|           |                 |                | All peripheral operation: Max.*6      | ICLK = 12 MHz |                 | _         | 10   | 1    |                    |
|           |                 | Sleep mode     | No peripheral operation*5             | ICLK = 12 MHz |                 | 1.0       | _    |      |                    |
|           |                 |                |                                       | ICLK = 8 MHz  | _               | 0.82      |      | 1    |                    |
|           |                 |                |                                       | ICLK = 1 MHz  |                 | 0.65      | _    |      |                    |
|           |                 |                | All peripheral operation:             | ICLK = 12 MHz |                 | 2.3       | _    |      |                    |
|           |                 |                | Normal*6                              | ICLK = 8 MHz  | 1               | 1.9       | _    |      |                    |
|           |                 |                |                                       | ICLK = 1 MHz  | 1               | 1.0       | _    |      |                    |
|           |                 | Deep sleep     | No peripheral operation*5             | ICLK = 12 MHz | 1               | 0.8       | _    |      |                    |
|           |                 | mode           |                                       | ICLK = 8 MHz  | 1               | 0.66      | _    |      |                    |
|           |                 |                |                                       | ICLK = 1 MHz  | 1               | 0.58      | _    |      |                    |
|           |                 |                | All peripheral operation:             | ICLK = 12 MHz | 1               | 1.6       | _    |      |                    |
|           |                 |                | Normal*6                              | ICLK = 8 MHz  | 1               | 1.5       | _    |      |                    |
|           |                 |                |                                       | ICLK = 1 MHz  |                 | 0.87      | _    |      |                    |

#### Table 32.7 DC Characteristics (5) (2/2)

Conditions: 1.8 V  $\leq$  VCC  $\leq$  3.6 V, 1.8 V  $\leq$  AVCC0  $\leq$  3.6 V, VSS = AVSS0 = 0 V,  $T_a = -40$  to +105°C

|            | Item                                    |                                       |                                           |                   |                 |      |   | Unit | Test<br>Conditions |
|------------|-----------------------------------------|---------------------------------------|-------------------------------------------|-------------------|-----------------|------|---|------|--------------------|
| Supply     | Low-speed                               | Normal                                | No peripheral operation*7                 | ICLK = 32.768 kHz | I <sub>CC</sub> | 3.9  | _ | μA   |                    |
| current*1  | operating mode operating mode           |                                       | All peripheral operation:<br>Normal*8, *9 | ICLK = 32.768 kHz |                 | 10.4 | _ |      |                    |
|            | All peripheral operation:<br>Max.*8, *9 | ICLK = 32.768 kHz                     |                                           | _                 | 36              |      |   |      |                    |
|            | Sleep mode                              |                                       | No peripheral operation*7                 | ICLK = 32.768 kHz |                 | 2.1  | _ |      |                    |
|            |                                         | All peripheral operation:<br>Normal*8 | ICLK = 32.768 kHz                         |                   | 5.6             | _    |   |      |                    |
| Deep sleep |                                         | No peripheral operation*7             | ICLK = 32.768 kHz                         |                   | 1.7             | _    |   |      |                    |
|            | mode                                    | mode                                  | All peripheral operation:<br>Normal*8     | ICLK = 32.768 kHz |                 | 3.9  | _ |      |                    |

- Note 1. Supply current values do not include output charge/discharge current from all pins. The values apply when internal pull-up MOSs are in the off state.
- Note 2. Clock supply to the peripheral functions is stopped. The clock source is HOCO. FCLK and PCLK are set to divided by 64.
- Note 3. Clocks are supplied to the peripheral functions. The clock source is HOCO. FCLK and PCLK are set to the same frequency as ICLK.
- Note 4. Values when VCC = 3.3 V.
- Note 5. Clock supply to the peripheral functions is stopped. The clock source is the main oscillation circuit when ICLK = 12 MHz and HOCO when ICLK = 8 or 1 MHz. FCLK and PCLK are set to divided by 64.
- Note 6. Clocks are supplied to the peripheral functions. The clock source is the main oscillation circuit when ICLK = 12 MHz and HOCO when ICLK = 8 or 1 MHz. FCLK and PCLK are set to the same frequency as ICLK.
- Note 7. Clock supply to the peripheral functions is stopped. The clock source is the sub-clock oscillator. FCLK and PCLK are set to divided by 64.
- Note 8. Clocks are supplied to the peripheral functions. The clock source is the sub-clock oscillator. FCLK and PCLK are set to the same frequency as ICLK.
- Note 9. Values when the MSTPCRA.MSTPA17 bit (12-bit A/D converter module stop bit) is set to "transition to the module stop state is made"



Figure 32.1 Voltage Dependency in High-Speed Operating Mode (Reference Data)



Figure 32.2 Voltage Dependency in Middle-Speed Operating Mode (Reference Data)



Figure 32.3 Voltage Dependency in Low-Speed Operating Mode (Reference Data)

Table 32.8 DC Characteristics (6)

|           | ltem                |                        | Symbol          | Typ.*3 | Max. | Unit | Test Conditions        |
|-----------|---------------------|------------------------|-----------------|--------|------|------|------------------------|
| Supply    | Software standby    | T <sub>a</sub> = 25°C  | I <sub>CC</sub> | 0.35   | 0.53 | μΑ   |                        |
| current*1 | mode*2              | T <sub>a</sub> = 55°C  |                 | 0.54   | 1.17 |      |                        |
|           |                     | T <sub>a</sub> = 85°C  |                 | 1.38   | 5.2  |      |                        |
|           |                     | T <sub>a</sub> = 105°C |                 | 2.8    | 11.4 |      |                        |
|           | Increment for RTC o | peration*4             |                 | 0.31   | _    |      | RCR3.RTCDV[2:0] = 010b |
|           |                     |                        |                 | 1.09   | _    |      | RCR3.RTCDV[2:0] = 100b |
|           | Increment for IWDT  | operation              | ]               | 0.37   | _    |      |                        |

- Note 1. Supply current values are with all output pins unloaded and all input pull-up MOSs in the off state.
- Note 2. The IWDT and LVD are stopped.
- Note 3. VCC = 3.3 V.
- Note 4. Includes the oscillation circuit.



Figure 32.4 Voltage Dependency in Software Standby Mode (Reference Data)



Figure 32.5 Temperature Dependency in Software Standby Mode (Reference Data)

Table 32.9 DC Characteristics (7)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}, 1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}, \text{VSS} = \text{AVSS0} = 0 \text{ V}$ 

| Item                                  | Symbol | Тур. | Max. | Unit | Test Conditions                             |
|---------------------------------------|--------|------|------|------|---------------------------------------------|
| Permissible total consumption power*1 | Pd     | _    | 300  | mW   | D version (T <sub>a</sub> = -40 to 85°C)    |
|                                       |        | _    | 105  |      | G version (T <sub>a</sub> = -40 to 105°C)*2 |

Note 1. Total power dissipated by the entire chip (including output currents).

Note 2. Please contact Renesas Electronics sales office for derating under T<sub>a</sub> = +85°C to 105°C. Derating is the systematic reduction of load for the sake of improved reliability.

#### Table 32.10 DC Characteristics (8)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

|                      | Item                                             | Symbol             | Min. | Typ.*2 | Max. | Unit | Test<br>Conditions |
|----------------------|--------------------------------------------------|--------------------|------|--------|------|------|--------------------|
| Analog power         | During A/D conversion (at high-speed conversion) | I <sub>AVCC</sub>  | _    | 0.7    | 1.2  | mA   |                    |
| supply current       | Waiting for A/D conversion (all units)           |                    | _    | _      | 0.3  | μA   |                    |
| Reference power      | During A/D conversion (at high-speed conversion) | I <sub>REFH0</sub> | _    | 25     | 52   | μA   |                    |
| supply current       | Waiting for A/D conversion (all units)           |                    | _    | _      | 60   | nA   |                    |
| Temperature sensor*1 |                                                  | I <sub>TEMP</sub>  | _    | 75     | _    | μA   |                    |
| LDV1, 2              | Per channel                                      | I <sub>LVD</sub>   | _    | 0.15   | _    | μA   |                    |

Note 1. Current consumed by the power supply (VCC).

Note 2. When VCC = AVCC0 = 3.3 V.

#### Table 32.11 DC Characteristics (9)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

| Item                | Symbol    | Min. | Тур. | Max. | Unit | Test Conditions |
|---------------------|-----------|------|------|------|------|-----------------|
| RAM standby voltage | $V_{RAM}$ | 1.8  | _    | 1    | V    |                 |

#### Table 32.12 DC Characteristics (10)

Conditions:  $0 \text{ V} \leq \text{VCC} \leq 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

| Item                |                                                     | Symbol | Min. | Тур. | Max. | Unit | Test Conditions |
|---------------------|-----------------------------------------------------|--------|------|------|------|------|-----------------|
| Power-on VCC rising | At normal startup*1                                 | SrVCC  | 0.02 | _    | 20   | ms/V |                 |
| gradient            | During fast startup time*2                          |        | 0.02 | _    | 2    |      |                 |
|                     | Voltage monitoring 1 reset enabled at startup*3, *4 |        | 0.02 | _    | _    |      |                 |

Note: When powering on AVCC0 and VCC, power them on at the same time or VCC first.

Note 1. When OFS1.(STUPLVD1REN, FASTSTUP) = 11b.

Note 2. When OFS1.(STUPLVD1REN, FASTSTUP) = 10b.

Note 3. When OFS1. $\overline{STUPLVD1REN} = 0$ .

Note 4. Turn on the power supply voltage according to the normal startup rising gradient because the register settings set by OFS1 are not read in boot mode.

# Table 32.13 DC Characteristics (11)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

The ripple voltage must meet the allowable ripple frequency  $f_{r(VCC)}$  within the range between the VCC upper limit (3.6 V) and lower limit (1.8 V).

When VCC change exceeds VCC ±10%, the allowable voltage change rising/falling gradient dt/dVCC must be met.

| Item                                                 | Symbol               | Min. | Тур. | Max. | Unit | Test Conditions                                  |
|------------------------------------------------------|----------------------|------|------|------|------|--------------------------------------------------|
| Allowable ripple frequency                           | f <sub>r (VCC)</sub> | _    | _    | 10   | kHz  | Figure 32.6<br>V <sub>r (VCC)</sub> ≤ VCC × 0.2  |
|                                                      |                      | _    | _    | 1    | MHz  | Figure 32.6<br>V <sub>r (VCC)</sub> ≤ VCC × 0.08 |
|                                                      |                      | _    | _    | 10   | MHz  | Figure 32.6<br>V <sub>r (VCC)</sub> ≤ VCC × 0.06 |
| Allowable voltage change rising/<br>falling gradient | dt/dVCC              | 1.0  | _    | _    | ms/V | When VCC change exceeds VCC ±10%                 |



Figure 32.6 Ripple Waveform

# Table 32.14 DC Characteristics (12)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

| Item                                              | Symbol           | Min. | Тур. | Max. | Unit | Test Conditions |
|---------------------------------------------------|------------------|------|------|------|------|-----------------|
| Permissible error of VCL pin external capacitance | C <sub>VCL</sub> | 1.4  | 4.7  | 7.0  | μF   |                 |

Note: The recommended capacitance is 4.7 µF. Variations in connected capacitors should be within the above range.

#### **Table 32.15 Permissible Output Currents (1)**

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,

 $T_a = -40 \text{ to } +85^{\circ}\text{C (D version)}$ 

|                                 | Item                                                                                                                     | Symbol           | Max. | Unit |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------|------------------|------|------|
| Permissible output low current  | Ports P40 to P44, P46, ports PJ6, PJ7                                                                                    | I <sub>OL</sub>  | 0.4  | mA   |
| (average value per pin)         | Ports other than above                                                                                                   |                  | 8.0  |      |
| Permissible output low current  | Ports P40 to P44, P46, ports PJ6, PJ7                                                                                    |                  | 0.4  |      |
| (maximum value per pin)         | Ports other than above                                                                                                   |                  | 8.0  |      |
| Permissible output low current  | Total of ports P40 to P44, P46, ports PJ6, PJ7                                                                           | Σl <sub>OL</sub> | 2.4  |      |
|                                 | Total of ports P03, P05, ports P26, P27, ports P30, P31                                                                  |                  | 30   |      |
|                                 | Total of ports P14 to P17, port P32, ports P54, P55, ports PB0, PB1, PB3, PB5 to PB7, ports PC2 to PC7, ports PH0 to PH3 |                  | 30   |      |
|                                 | Total of ports PA0, PA1, PA3, PA4, PA6, ports PE0 to PE7                                                                 |                  | 30   |      |
|                                 | Total of all output pins                                                                                                 |                  | 60   |      |
| Permissible output high current | Ports P40 to P44, P46, ports PJ6, PJ7                                                                                    | I <sub>OH</sub>  | -0.1 |      |
| (average value per pin)         | Ports other than above                                                                                                   |                  | -4.0 |      |
| Permissible output high current | Ports P40 to P44, P46, ports PJ6, PJ7                                                                                    |                  | -0.1 |      |
| (maximum value per pin)         | Ports other than above                                                                                                   |                  | -4.0 |      |
| Permissible output high current | Total of ports P40 to P44, P46, ports PJ6, PJ7                                                                           | Σl <sub>OH</sub> | -0.6 |      |
|                                 | Total of ports P03, P05, ports P26, P27, ports P30, P31                                                                  |                  | -10  |      |
|                                 | Total of ports P14 to P17, port P32, ports P54, P55, ports PB0, PB1, PB3, PB5 to PB7, ports PC2 to PC7, ports PH0 to PH3 |                  | -15  |      |
|                                 | Total of ports PA0, PA1, PA3, PA4, PA6, ports PE0 to PE7                                                                 |                  | -15  |      |
|                                 | Total of all output pins                                                                                                 |                  | -40  |      |

Note: Do not exceed the permissible total supply current.

Table 32.16 Permissible Output Currents (2)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105^{\circ}\text{C} \text{ (G version)}$ 

|                                 | Item                                                                                                                     | Symbol           | Max. | Unit |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------|------------------|------|------|
| Permissible output low current  | Ports P40 to P44, P46, ports PJ6, PJ7                                                                                    | I <sub>OL</sub>  | 0.4  | mA   |
| (average value per pin)         | Ports other than above                                                                                                   |                  | 8.0  |      |
| Permissible output low current  | Ports P40 to P44, P46, ports PJ6, PJ7                                                                                    |                  | 0.4  |      |
| (maximum value per pin)         | Ports other than above                                                                                                   |                  | 8.0  |      |
| Permissible output low current  | Total of ports P40 to P44, P46, ports PJ6, PJ7                                                                           | $\Sigma I_{OL}$  | 1.6  |      |
|                                 | Total of ports P03, P05, ports P26, P27, ports P30, P31                                                                  |                  | 20   |      |
|                                 | Total of ports P14 to P17, port P32, ports P54, P55, ports PB0, PB1, PB3, PB5 to PB7, ports PC2 to PC7, ports PH0 to PH3 |                  | 20   |      |
|                                 | Total of ports PA0, PA1, PA3, PA4, PA6, ports PE0 to PE7                                                                 |                  | 20   |      |
|                                 | Total of all output pins                                                                                                 |                  | 40   |      |
| Permissible output high current | Ports P40 to P44, P46, ports PJ6, PJ7                                                                                    | I <sub>OH</sub>  | -0.1 |      |
| (average value per pin)         | Ports other than above                                                                                                   |                  | -4.0 |      |
| Permissible output high current | Ports P40 to P44, P46, ports PJ6, PJ7                                                                                    |                  | -0.1 |      |
| (maximum value per pin)         | Ports other than above                                                                                                   |                  | -4.0 |      |
| Permissible output high current | Total of ports P40 to P44, P46, ports PJ6, PJ7                                                                           | Σl <sub>OH</sub> | -0.6 |      |
|                                 | Total of ports P03, P05, ports P26, P27, ports P30, P31                                                                  |                  | -10  |      |
|                                 | Total of ports P14 to P17, port P32, ports P54, P55, ports PB0, PB1, PB3, PB5 to PB7, ports PC2 to PC7, ports PH0 to PH3 |                  | -15  |      |
|                                 | Total of ports PA0, PA1, PA3, PA4, PA6, ports PE0 to PE7                                                                 |                  | -15  |      |
|                                 | Total of all output pins                                                                                                 |                  | -40  |      |

Note: Do not exceed the permissible total supply current.

# Table 32.17 Output Voltage (1)

Conditions:  $2.7 \text{ V} \le \text{VCC} \le 3.6 \text{ V}, 2.7 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}, \text{VSS} = \text{AVSS0} = 0 \text{ V}, \text{T}_a = -40 \text{ to } +10^{\circ}\text{C}$ 

|                           | Item                                                     |                                      | Symbol          | Min.        | Max. | Unit | Test Conditions           |
|---------------------------|----------------------------------------------------------|--------------------------------------|-----------------|-------------|------|------|---------------------------|
| Low-level                 | All output ports                                         |                                      | V <sub>OL</sub> | _           | 0.6  | V    | I <sub>OL</sub> = 3.0 mA  |
| output voltage            | (except for RIIC, ports P40 to P44, P46, ports PJ6, PJ7) |                                      |                 | _           | 0.4  |      | I <sub>OL</sub> = 1.5 mA  |
|                           | Ports P40 to P44, P46, ports PJ6, PJ7                    |                                      |                 | _           | 0.4  |      | I <sub>OL</sub> = 0.4 mA  |
|                           | RIIC pins                                                | Standard mode                        |                 | _           | 0.4  |      | I <sub>OL</sub> = 3.0 mA  |
|                           |                                                          | Fast mode                            |                 | _           | 0.6  |      | I <sub>OL</sub> = 6.0 mA  |
| High-level output voltage | All output ports (<br>P46, ports PJ6, I                  | except for ports P40 to P44,<br>PJ7) | V <sub>OH</sub> | VCC - 0.5   | _    | V    | I <sub>OH</sub> = -2.0 mA |
|                           | Ports P40 to P44                                         | I, P46, ports PJ6, PJ7               |                 | AVCC0 - 0.5 |      |      | I <sub>OH</sub> = -0.1 mA |

# Table 32.18 Output Voltage (2)

|                           | Item                                                                      | Symbol          | Min.        | Max. | Unit | Test Conditions           |
|---------------------------|---------------------------------------------------------------------------|-----------------|-------------|------|------|---------------------------|
| Low-level output voltage  | All output ports<br>(except for ports P40 to P44, P46,<br>ports PJ6, PJ7) | V <sub>OL</sub> | _           | 0.6  | V    | I <sub>OL</sub> = 1.5 mA  |
|                           | Ports P40 to P44, P46, ports PJ6, PJ7                                     |                 | _           | 0.4  |      | I <sub>OL</sub> = 0.4 mA  |
| High-level output voltage | All output ports (except for ports P40 to P44, P46, ports PJ6, PJ7)       | V <sub>OH</sub> | VCC - 0.5   | _    | V    | I <sub>OH</sub> = -1.0 mA |
|                           | Ports P40 to P44, P46, ports PJ6, PJ7                                     |                 | AVCC0 - 0.5 | _    |      | I <sub>OH</sub> = -0.1 mA |

# 32.2.1 Standard I/O Pin Output Characteristics (1)

Figure 32.7 to Figure 32.10 show the characteristics of general ports (except for the RIIC output pin, ports P40 to P44, P46, ports PJ6, PJ7).



Figure 32.7  $V_{OH}/V_{OL}$  and  $I_{OH}/I_{OL}$  Voltage Characteristics of General Ports (Except for the RIIC Output Pin, Ports P40 to P44, P46, Ports PJ6, PJ7) at  $T_a = 25$ °C (Reference Data)



Figure 32.8 V<sub>OH</sub>/V<sub>OL</sub> and I<sub>OH</sub>/I<sub>OL</sub> Temperature Characteristics of General Ports (Except for the RIIC Output Pin, Ports P40 to P44, P46, Ports PJ6, PJ7) at VCC = 1.8 V (Reference Data)



Figure 32.9 V<sub>OH</sub>/V<sub>OL</sub> and I<sub>OH</sub>/I<sub>OL</sub> Temperature Characteristics of General Ports (Except for the RIIC Output Pin, Ports P40 to P44, P46, Ports PJ6, PJ7) at VCC = 2.7 V (Reference Data)



Figure 32.10 V<sub>OH</sub>/V<sub>OL</sub> and I<sub>OH</sub>/I<sub>OL</sub> Temperature Characteristics of General Ports (Except for the RIIC Output Pin, Ports P40 to P44, P46, Ports PJ6, PJ7) at VCC = 3.3 V (Reference Data)

# 32.2.2 Standard I/O Pin Output Characteristics (2)

Figure 32.11 to Figure 32.13 show the characteristics of the RIIC output pin.



Figure 32.11  $V_{OL}$  and  $I_{OL}$  Voltage Characteristics of RIIC Output Pin at  $T_a = 25^{\circ}$ C (Reference Data)



Figure 32.12 V<sub>OL</sub> and I<sub>OL</sub> Temperature Characteristics of RIIC Output Pin at VCC = 2.7 V (Reference Data)



Figure 32.13 V<sub>OL</sub> and I<sub>OL</sub> Temperature Characteristics of RIIC Output Pin at VCC = 3.3 V (Reference Data)

32. Electrical Characteristics

# 32.2.3 Standard I/O Pin Output Characteristics (3)

Figure 32.14 to Figure 32.17 show the characteristics ports P40 to P44, P46, ports PJ6, PJ7.



Figure 32.14  $V_{OH}/V_{OL}$  and  $I_{OH}/I_{OL}$  Voltage Characteristics of Ports P40 to P44, P46, Ports PJ6, PJ7 at  $T_a = 25$ °C (Reference Data)



Figure 32.15  $V_{OH}/V_{OL}$  and  $I_{OH}/I_{OL}$  Temperature Characteristics of Ports P40 to P44, P46, Ports PJ6, PJ7 at VCC = 1.8 V (Reference Data)



Figure 32.16  $V_{OH}/V_{OL}$  and  $I_{OH}/I_{OL}$  Temperature Characteristics of Ports P40 to P44, P46, Ports PJ6, PJ7 at VCC = 2.7 V (Reference Data)



Figure 32.17  $V_{OH}/V_{OL}$  and  $I_{OH}/I_{OL}$  Temperature Characteristics of Ports P40 to P44, P46, Ports PJ6, PJ7 at VCC = 3.3 V (Reference Data)

#### 32.3 AC Characteristics

#### 32.3.1 Clock Timing

Table 32.19 Operation Frequency Value (High-Speed Operating Mode)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

| Item              |                                   | Symbol |              | Unit         |              |       |
|-------------------|-----------------------------------|--------|--------------|--------------|--------------|-------|
|                   |                                   | Symbol | 1.8 to 2.4 V | 2.4 to 2.7 V | 2.7 to 3.6 V | Offic |
| Maximum operating | System clock (ICLK)               |        | 8            | 16           | 32           | MHz   |
| frequency         | FlashIF clock (FCLK)*1, *2        |        | 8            | 16           | 32           |       |
|                   | Peripheral module clock (PCLKB)   |        | 8            | 16           | 32           |       |
|                   | Peripheral module clock (PCLKD)*3 |        | 8            | 16           | 32           | 1     |

Note 1. The lower-limit frequency of FCLK is 1 MHz during programming or erasing of the flash memory. When using FCLK at below 4 MHz, the frequency can be set to 1 MHz, 2 MHz, or 3 MHz. A non-integer frequency such as 1.5 MHz cannot be set.

Table 32.20 Operation Frequency Value (Middle-Speed Operating Mode)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

| Item              |                                   | Symbol           |              | Unit         |              |       |
|-------------------|-----------------------------------|------------------|--------------|--------------|--------------|-------|
|                   |                                   | Cymbol           | 1.8 to 2.4 V | 2.4 to 2.7 V | 2.7 to 3.6 V | Offic |
| Maximum operating | System clock (ICLK)               | f <sub>max</sub> | 8            | 12           | 12           | MHz   |
| frequency         | FlashIF clock (FCLK)*1, *2        | 1                | 8            | 12           | 12           |       |
|                   | Peripheral module clock (PCLKB)   |                  | 8            | 12           | 12           |       |
|                   | Peripheral module clock (PCLKD)*3 | 1                | 8            | 12           | 12           |       |

Note 1. The lower-limit frequency of FCLK is 1 MHz during programming or erasing of the flash memory. When using FCLK at below 4 MHz, the frequency can be set to 1 MHz, 2 MHz, or 3 MHz. A non-integer frequency such as 1.5 MHz cannot be set.

#### **Table 32.21 Operation Frequency Value (Low-Speed Operating Mode)**

|                   | Item                              |                                    |              | Unit         |              |       |  |
|-------------------|-----------------------------------|------------------------------------|--------------|--------------|--------------|-------|--|
| KOIII             |                                   | Symbol                             | 1.8 to 2.4 V | 2.4 to 2.7 V | 2.7 to 3.6 V | Offic |  |
| Maximum operating | System clock (ICLK)               | f <sub>max</sub>                   |              |              | kHz          |       |  |
| frequency         | FlashIF clock (FCLK)*1            |                                    |              |              |              |       |  |
|                   | Peripheral module clock (PCLKB)   | 32.768                             |              |              |              |       |  |
|                   | Peripheral module clock (PCLKD)*2 | eral module clock (PCLKD)*2 32.768 |              |              |              |       |  |

Note 1. Programming and erasing the flash memory is impossible.

Note 2. The frequency accuracy of FCLK should be ±3.5%. Confirm the frequency accuracy of the clock source.

Note 3. The lower-limit frequency of PCLKD is 4 MHz at 2.4 V or above and 1 MHz at below 2.4 V when the A/D converter is in use.

Note 2. The frequency accuracy of FCLK should be ±3.5%.

Note 3. The lower-limit frequency of PCLKD is 4 MHz at 2.4 V or above and 1 MHz at below 2.4 V when the A/D converter is in use.

Note 2. The A/D converter cannot be used.

Table 32.22 Clock Timing

| Item                                                                                  |              | Symbol               | Min.  | Тур.   | Max.  | Unit | Test Conditions                             |
|---------------------------------------------------------------------------------------|--------------|----------------------|-------|--------|-------|------|---------------------------------------------|
| XTAL external clock input cycle time                                                  |              | t <sub>Xcyc</sub>    | 50    | _      | _     | ns   | Figure 32.18                                |
| XTAL external clock input high pulse width                                            |              | t <sub>XH</sub>      | 20    | _      | _     | ns   |                                             |
| XTAL external clock input low pulse width                                             |              | t <sub>XL</sub>      | 20    | _      | _     | ns   |                                             |
| XTAL external clock rising time                                                       |              | t <sub>Xr</sub>      | _     | _      | 5     | ns   |                                             |
| XTAL external clock falling time                                                      |              | t <sub>Xf</sub>      | _     | _      | 5     | ns   |                                             |
| XTAL external clock input wait time*1                                                 |              | t <sub>EXWT</sub>    | 0.5   | _      | _     | μs   |                                             |
| Main clock oscillator oscillation frequency $2.4 \le VCC \le 3.6$ $1.8 \le VCC < 2.4$ |              | f <sub>MAIN</sub>    | 1     | _      | 20    | MHz  |                                             |
|                                                                                       |              |                      | 1     | _      | 8     |      |                                             |
| Main clock oscillation stabilization time (crystal)*2                                 |              | t <sub>MAINOSC</sub> |       | 3      | _     | ms   | Figure 32.20                                |
| Main clock oscillation stabilization time (ceramic                                    | resonator)*2 | t <sub>MAINOSC</sub> | _     | 50     |       | μs   |                                             |
| LOCO clock oscillation frequency                                                      |              | f <sub>LOCO</sub>    | 3.44  | 4.0    | 4.56  | MHz  |                                             |
| LOCO clock oscillation stabilization time                                             |              | t <sub>LOCO</sub>    | _     | _      | 0.5   | μs   | Figure 32.21                                |
| IWDT-dedicated clock oscillation frequency                                            |              | f <sub>ILOCO</sub>   | 12.75 | 15     | 17.25 | kHz  |                                             |
| IWDT-dedicated clock oscillation stabilization tin                                    | ne           | t <sub>ILOCO</sub>   | _     | _      | 50    | μs   | Figure 32.19                                |
| HOCO clock oscillation frequency                                                      |              | f <sub>HOCO</sub>    | 31.52 | 32     | 32.48 | MHz  | $T_a = -40 \text{ to } 85^{\circ}\text{C}$  |
|                                                                                       |              |                      | 31.68 | 32     | 32.32 |      | $T_a = -20 \text{ to } 85^{\circ}\text{C}$  |
|                                                                                       |              |                      | 31.36 | 32     | 32.64 |      | $T_a = -40 \text{ to } 105^{\circ}\text{C}$ |
| HOCO clock oscillation stabilization time                                             |              | t <sub>HOCO2</sub>   | _     | _      | 56    | μs   | Figure 32.23                                |
| Sub-clock oscillator oscillation frequency*4                                          |              | f <sub>SUB</sub>     | _     | 32.768 | _     | kHz  |                                             |
| Sub-clock oscillation stabilization time*3                                            |              | t <sub>SUBOSC</sub>  | _     | 0.5    | _     | S    | Figure 32.24                                |

- Note 1. Time until the clock can be used after the main clock oscillator stop bit (MOSCCR.MOSTP) is set to 0 (operating) when the external clock is stable.
- Note 2. Reference values when an 8-MHz oscillator is used.
  - When specifying the main clock oscillator stabilization time, set the MOSCWTCR register with a stabilization time value that is equal to or greater than the oscillator-manufacturer-recommended value.
  - After changing the setting of the MOSCCR.MOSTP bit so that the main clock oscillator operates, read the OSCOVFSR.MOOVF flag to confirm that is has become 1, and then start using the main clock.
- Note 3. After changing the setting of the SOSCCR.SOSTP bit or RCR3.RTCEN bit so that the sub-clock oscillator operates, only start using the sub-clock after the sub-clock oscillation stabilization wait time that is equal to or greater than the oscillator-manufacturer-recommended value has elapsed.
  - Reference value when a 32.768-kHz resonator is used.
- Note 4. Only 32.768 kHz can be used.



Figure 32.18 XTAL External Clock Input Timing



Figure 32.19 IWDT-Dedicated Clock Oscillation Start Timing



Figure 32.20 Main Clock Oscillation Start Timing



Figure 32.21 LOCO Clock Oscillation Start Timing



Figure 32.22 HOCO Clock Oscillation Start Timing (After Reset is Canceled by Setting OFS1.HOCOEN Bit to 0)



Figure 32.23 HOCO Clock Oscillation Start Timing (Oscillation is Started by Setting HOCOCR.HCSTP Bit)



Figure 32.24 Sub-Clock Oscillation Start Timing

# 32.3.2 Reset Timing

Table 32.23 Reset Timing

| Item                                                            |                            | Symbol              | Min. | Тур. | Max. | Unit             | Test Conditions |
|-----------------------------------------------------------------|----------------------------|---------------------|------|------|------|------------------|-----------------|
| RES# pulse width                                                | At power-on                | t <sub>RESWP</sub>  | 3    | _    | _    | ms               | Figure 32.25    |
|                                                                 | Other than above           | t <sub>RESW</sub>   | 30   | _    | _    | μs               | Figure 32.26    |
| Wait time after RES# cancellation (at power-on)                 | At normal startup*1        | t <sub>RESWT</sub>  | _    | 8.5  | _    | ms               | Figure 32.25    |
|                                                                 | During fast startup time*2 | t <sub>RESWT</sub>  | _    | 560  | _    | μs               | ]               |
| Wait time after RES# cancellation (during powered-on state)     |                            | t <sub>RESWT</sub>  | _    | 114  | _    | μs               | Figure 32.26    |
| Independent watchdog timer reset p                              | period                     | t <sub>RESWIW</sub> | _    | 1    | _    | IWDT clock cycle | Figure 32.27    |
| Software reset period                                           |                            | t <sub>RESWSW</sub> | _    | 1    | _    | ICLK cycle       |                 |
| Wait time after independent watchdog timer reset cancellation*3 |                            | t <sub>RESW2</sub>  | _    | 300  | _    | μs               | 1               |
| Wait time after software reset cance                            | ellation                   | t <sub>RESW2</sub>  | _    | 168  | _    | μs               | 1               |

- Note 1. When OFS1.(STUPLVD1REN, FASTSTUP) = 11b.
- Note 2. When OFS1.(STUPLVD1REN, FASTSTUP) ≠ 11b.
- Note 3. When IWDTCR.CKS[3:0] = 0000b.



Figure 32.25 Reset Input Timing at Power-On



Figure 32.26 Reset Input Timing (1)



Figure 32.27 Reset Input Timing (2)

#### 32.3.3 Timing of Recovery from Low Power Consumption Modes

Table 32.24 Timing of Recovery from Low Power Consumption Modes (1)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

|                                            | Item                            |                                                     |                                   |                    | Min.           | Тур. | Max. | Unit         | Test<br>Conditions |
|--------------------------------------------|---------------------------------|-----------------------------------------------------|-----------------------------------|--------------------|----------------|------|------|--------------|--------------------|
| Recovery time from software standby mode*1 | High-speed<br>mode              | Crystal<br>connected to<br>main clock<br>oscillator | Main clock oscillator operating*2 | t <sub>SBYMC</sub> | SBYMC — 2 3 ms |      | ms   | Figure 32.28 |                    |
|                                            |                                 | External clock input to main clock oscillator       | Main clock oscillator operating*3 | t <sub>SBYEX</sub> | _              | 35   | 50   | μs           |                    |
|                                            |                                 | Sub-clock oscillate                                 | or operating                      | t <sub>SBYSC</sub> | _              | 650  | 800  | μs           |                    |
|                                            |                                 | HOCO clock oscillator operating*4                   |                                   | t <sub>SBYHO</sub> | _              | 40   | 55   | μs           |                    |
|                                            | LOCO clock oscillator operating |                                                     | t <sub>SBYLO</sub>                | _                  | 40             | 55   | μs   |              |                    |

- Note: When the division ratios of PCLKB, PCLKD, FCLK, and ICLK are all set to 1.
- Note 1. The recovery time varies depending on the state of each oscillator when the WAIT instruction is executed. The recovery time when multiple oscillators are operating varies depending on the operating state of the oscillators that are not selected as the system clock source. This applies when only the oscillator listed in each item is operating and the other oscillators are stopped.
- Note 2. When the frequency of the crystal is 20 MHz.
  - When the main clock oscillator wait control register (MOSCWTCR) is set to 04h.
- Note 3. When the frequency of the external clock is 20 MHz.

  When the main clock oscillator wait control register (MOSCWTCR) is set to 00h.
- Note 4. When the frequency of HOCO is 32 MHz.

  When the high-speed clock oscillator wait control register (HOCOWTCR) is set to 05h.

Table 32.25 Timing of Recovery from Low Power Consumption Modes (2)

| ltem . |                   |                                                     | Symbol                            | Min.               | Тур. | Max. | Unit | Test<br>Conditions |              |
|--------|-------------------|-----------------------------------------------------|-----------------------------------|--------------------|------|------|------|--------------------|--------------|
| ,      | Middle-speed mode | Crystal<br>connected to<br>main clock<br>oscillator | Main clock oscillator operating*2 | t <sub>SBYMC</sub> | _    | 2    | 3    | ms                 | Figure 32.28 |
|        |                   | External clock input to main clock oscillator       | Main clock oscillator operating*3 | t <sub>SBYEX</sub> | _    | 3    | 4    | μs                 |              |
|        |                   | Sub-clock oscillate                                 | or operating                      | t <sub>SBYSC</sub> | _    | 600  | 750  | μs                 |              |
|        |                   | HOCO clock oscill                                   | ator operating*4                  | t <sub>SBYHO</sub> |      | 40   | 50   | μs                 |              |
|        |                   | LOCO clock oscill                                   | ator operating                    | t <sub>SBYLO</sub> | _    | 4.8  | 7    | μs                 |              |

- Note: When the division ratios of PCLKB, PCLKD, FCLK, and ICLK are all set to 1.
- Note 1. The recovery time varies depending on the state of each oscillator when the WAIT instruction is executed. The recovery time when multiple oscillators are operating varies depending on the operating state of the oscillators that are not selected as the system clock source. This applies when only the oscillator listed in each item is operating and the other oscillators are stopped.
- Note 2. When the frequency of the crystal is 12 MHz.
  - When the main clock oscillator wait control register (MOSCWTCR) is set to 04h.
- Note 3. When the frequency of the external clock is 12 MHz.
  - When the main clock oscillator wait control register (MOSCWTCR) is set to 00h.
- Note 4. When the frequency of HOCO is 8 MHz.
  - When the high-speed clock oscillator wait control register (HOCOWTCR) is set to 05h.



Table 32.26 Timing of Recovery from Low Power Consumption Modes (3)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

| Item                                             |                |                                |                    | Min. | Тур. | Max. | Unit | Test<br>Conditions |
|--------------------------------------------------|----------------|--------------------------------|--------------------|------|------|------|------|--------------------|
| Recovery time<br>from software<br>standby mode*1 | Low-speed mode | Sub-clock oscillator operating | t <sub>SBYSC</sub> | _    | 600  | 750  | μs   | Figure 32.28       |

Note: When the division ratios of PCLKB, PCLKD, FCLK, and ICLK are all set to 1.

Note 1. The sub-clock continues oscillating in software standby mode during low-speed mode.



Figure 32.28 Software Standby Mode Cancellation Timing

Table 32.27 Timing of Recovery from Low Power Consumption Modes (4)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}, 1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}, \text{VSS} = \text{AVSS0} = 0 \text{ V}, \text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

| Ito                     | Symbol              | Min.              | Тур. | Max. | Unit | Test Conditions |  |
|-------------------------|---------------------|-------------------|------|------|------|-----------------|--|
| Recovery time from deep | High-speed mode*2   | t <sub>DSLP</sub> | _    | 2    | 3.5  | μs              |  |
| sleep mode*1            | Middle-speed mode*3 | t <sub>DSLP</sub> | _    | 3    | 4    | μs              |  |
|                         | Low-speed mode*4    | t <sub>DSLP</sub> | _    | 400  | 500  | μs              |  |

Note: When the division ratios of PCLKB, PCLKD, FCLK, and ICLK are all set to 1.

Note 1. Oscillators continue oscillating in deep sleep mode.

Note 2. When the frequency of the system clock is 32 MHz.

Note 3. When the frequency of the system clock is 12 MHz.

Note 4. When the frequency of the system clock is 32.768 kHz.



Figure 32.29 Deep Sleep Mode Cancellation Timing

# Table 32.28 Timing of Recovery from Low Power Consumption Modes (5) Operating Mode Transition Time

Conditions:  $1.8 \text{ V} \leq \text{VCC} \leq 3.6 \text{ V}, 1.8 \text{ V} \leq \text{AVCC0} \leq 3.6 \text{ V}, \text{VSS} = \text{AVSS0} = 0 \text{ V}, \text{T}_{a} = -40 \text{ to } +105^{\circ}\text{C}$ 

| Mode before Transition                                 | Mode after Transition                                  | ICLK Frequency | Т    | Unit   |      |       |
|--------------------------------------------------------|--------------------------------------------------------|----------------|------|--------|------|-------|
|                                                        | Wiode after Transition                                 | IOER Frequency | Min. | Тур.   | Max. | Offic |
| High-speed operating mode                              | Middle-speed operating mode                            | 8 MHz          | _    | 10     | _    | μs    |
| Middle-speed operating mode                            | High-speed operating mode                              | 8 MHz          | _    | 37.5   | _    | μs    |
| Low-speed operating mode                               | Middle-speed operating mode, high-speed operating mode | 32.768 kHz     | _    | 213.62 | _    | μs    |
| Middle-speed operating mode, high-speed operating mode | Low-speed operating mode                               | 32.768 kHz     | _    | 183.11 | _    | μs    |

Note: When the division ratios of PCLKB, PCLKD, FCLK, and ICLK are all set to 1.

#### **Control Signal Timing** 32.3.4

Table 32.29 Control Signal Timing

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}, 1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}, \text{VSS} = \text{AVSS0} = 0 \text{ V}, \text{T}_a = -40 \text{ to } +105^{\circ}\text{C}$ 

| Item            | Symbol            | Min.                        | Тур. | Max. | Unit | Test Condition              | S                               |
|-----------------|-------------------|-----------------------------|------|------|------|-----------------------------|---------------------------------|
| NMI pulse width | t <sub>NMIW</sub> | 200                         | _    | _    | ns   | NMI digital filter disabled | t <sub>Pcyc</sub> × 2 ≤ 200 ns  |
|                 |                   | t <sub>Pcyc</sub> × 2*1     | _    | _    |      | (NMIFLTE.NFLTEN = 0)        | t <sub>Pcyc</sub> x 2 > 200 ns  |
|                 |                   | 200                         | _    | _    |      | NMI digital filter enabled  | t <sub>NMICK</sub> × 3 ≤ 200 ns |
|                 |                   | $t_{NMICK} \times 3.5^{*2}$ | _    | _    |      | (NMIFLTE.NFLTEN = 1)        | t <sub>NMICK</sub> × 3 > 200 ns |
| IRQ pulse width | t <sub>IRQW</sub> | 200                         | _    | _    | ns   | IRQ digital filter disabled | t <sub>Pcyc</sub> × 2 ≤ 200 ns  |
|                 |                   | t <sub>Pcyc</sub> × 2*1     | _    | _    |      | (IRQFLTE0.FLTENi = 0)       | t <sub>Pcyc</sub> x 2 > 200 ns  |
|                 |                   | 200                         | _    | _    |      | IRQ digital filter enabled  | t <sub>IRQCK</sub> × 3 ≤ 200 ns |
|                 |                   | t <sub>IRQCK</sub> × 3.5*3  | _    | _    |      | (IRQFLTE0.FLTENi = 1)       | t <sub>IRQCK</sub> × 3 > 200 ns |

Note: 200 ns minimum in software standby mode.

Note 1.  $t_{Pcyc}$  indicates the cycle of PCLKB.

Note 2.  $t_{NMICK}$  indicates the cycle of the NMI digital filter sampling clock. Note 3.  $t_{IRQCK}$  indicates the cycle of the IRQi digital filter sampling clock (i = 0 to 7).



Figure 32.30 NMI Interrupt Input Timing



Figure 32.31 IRQ Interrupt Input Timing

# 32.3.5 Timing of On-Chip Peripheral Modules

Table 32.30 Timing of On-Chip Peripheral Modules (1)

|                  | ľ                                             | tem                  |                                              | Symbol               | Min.                                       | Max. | Unit*1            | Test<br>Conditions |
|------------------|-----------------------------------------------|----------------------|----------------------------------------------|----------------------|--------------------------------------------|------|-------------------|--------------------|
| I/O ports        | Input data pulse width                        |                      |                                              | t <sub>PRW</sub>     | 1.5                                        | _    | t <sub>Pcyc</sub> | Figure 32.32       |
| MTU2             | Input capture input pulse                     | vidth                | Single-edge setting                          | t <sub>TICW</sub>    | 1.5                                        | _    | t <sub>Pcyc</sub> | Figure 32.33       |
|                  |                                               |                      | Both-edge setting                            |                      | 2.5                                        | _    |                   |                    |
|                  | Timer clock pulse width                       |                      | Single-edge setting                          | t <sub>TCKWH</sub> , | 1.5                                        | _    | t <sub>Pcyc</sub> | Figure 32.34       |
|                  |                                               |                      | Both-edge setting                            | t <sub>TCKWL</sub>   | 2.5                                        | _    |                   |                    |
|                  |                                               |                      | Phase counting mode                          |                      | 2.5                                        | _    |                   |                    |
| SCI              | Input clock cycle                             |                      | Asynchronous                                 | t <sub>Scyc</sub>    | 4                                          | _    | t <sub>Pcyc</sub> | Figure 32.35       |
|                  |                                               |                      | Clock synchronous                            |                      | 6                                          | _    |                   |                    |
|                  | Input clock pulse width                       |                      |                                              | t <sub>SCKW</sub>    | 0.4                                        | 0.6  | t <sub>Scyc</sub> |                    |
|                  | Input clock rise time                         |                      |                                              | t <sub>SCKr</sub>    | _                                          | 20   | ns                |                    |
|                  | Input clock fall time                         |                      |                                              | t <sub>SCKf</sub>    | _                                          | 20   | ns                |                    |
|                  | Output clock cycle                            |                      | Asynchronous                                 | t <sub>Scyc</sub>    | 16                                         | _    | t <sub>Pcyc</sub> | Figure 32.36       |
|                  |                                               |                      | Clock synchronous                            |                      | 4                                          | _    |                   | C = 30 pF          |
|                  | Output clock pulse width                      |                      |                                              | t <sub>SCKW</sub>    | 0.4                                        | 0.6  | t <sub>Scyc</sub> | -                  |
|                  | Output clock rise time                        |                      |                                              | t <sub>SCKr</sub>    | _                                          | 20   | ns                | -                  |
|                  | Output clock fall time                        |                      |                                              | t <sub>SCKf</sub>    | _                                          | 20   | ns                |                    |
|                  | Transmit data delay time Clock synchromaster) |                      | nous                                         | t <sub>TXD</sub>     | t <sub>TXD</sub> —                         |      | ns                |                    |
|                  | Transmit data delay time (slave)              | Clock<br>synchronous | 2.7 V or above                               |                      | _                                          | 65   | ns                |                    |
|                  |                                               |                      | 1.8 V or above                               |                      | _                                          | 100  | ns                |                    |
|                  | Receive data setup time                       | Clock                | 2.7 V or above                               | t <sub>RXS</sub>     | 65                                         | _    | ns                |                    |
|                  | (master)                                      | synchronous          | 1.8 V or above                               |                      | 90                                         | _    | ns                |                    |
|                  | Receive data setup time (slave)               | Clock synchro        | nous                                         |                      | 40                                         | _    | ns                |                    |
|                  | Receive data hold time                        | Clock synchro        | nous                                         | t <sub>RXH</sub>     | 40                                         | _    | ns                | 1                  |
| A/D<br>converter | Trigger input pulse width                     | •                    |                                              | t <sub>TRGW</sub>    | 1.5                                        | _    | t <sub>Pcyc</sub> | Figure 32.37       |
| CAC              | CACREF input pulse width                      | 1                    | t <sub>Pcyc</sub> ≤ t <sub>cac</sub> *2      | tCACREF              | 4.5 t <sub>cac</sub> + 3 t <sub>Pcyc</sub> | _    | ns                |                    |
|                  |                                               |                      | $t_{Pcyc} > t_{cac}^{*2}$                    |                      | 5 t <sub>cac</sub> + 6.5 t <sub>Pcyc</sub> |      |                   |                    |
| CLKOUT           | CLKOUT pin output cycle                       | 4                    | VCC = 2.7 V or above                         | t <sub>Ccyc</sub>    | 125                                        | _    | ns                |                    |
|                  |                                               |                      | VCC = 1.8 V or above                         |                      | 250                                        |      |                   |                    |
|                  | CLKOUT pin high pulse w                       | idth* <sup>3</sup>   | VCC = 2.7 V or above                         | t <sub>CH</sub>      | 35                                         | _    | ns                |                    |
|                  | CLKOUT pin low pulse wie                      | Hth*3                | VCC = 1.8 V or above<br>VCC = 2.7 V or above | t <sub>CL</sub>      | 70<br>35                                   |      | ns                |                    |
|                  | OLICOT pirriow pulse wit                      | atti                 | VCC = 1.8 V or above                         | - CL                 | 70                                         |      | 110               |                    |
|                  | CLKOUT pin output rise ti                     | me                   | VCC = 2.7 V or above                         | t <sub>Cr</sub>      | _                                          | 15   | ns                | 1                  |
|                  |                                               |                      | VCC = 1.8 V or above                         | 1                    |                                            | 30   |                   |                    |
|                  | CLKOUT pin output fall tin                    | ne                   | VCC = 2.7 V or above                         | t <sub>Cf</sub>      | _                                          | 15   | ns                | ]                  |
|                  |                                               |                      | VCC = 1.8 V or above                         |                      |                                            | 30   |                   |                    |

Note 1. t<sub>Pcyc</sub>: PCLK cycle

Note 2. t<sub>cac</sub>: CAC count clock source cycle

Note 3. When the LOCO is selected as the clock output source (CKOCR.CKOSEL[2:0] bits = 000b), set the clock output division ratio selection to divided by 2 (CKOCR.CKODIV[2:0] bits = 001b).

Note 4. When the XTAL external clock input or an oscillator is used with divided by 1 (CKOCR.CKOSEL[2:0] bits = 010b and CKOCR.CKODIV[2:0] bits = 000b) to output from CLKOUT, the above should be satisfied with an input duty cycle of 45 to 55%.

Table 32.31 Timing of On-Chip Peripheral Modules (2)

|     |                                 | Item                                            |                                                             | Symbol                            | Min.                                                                     | Max.                                           | Unit              | Test Condition |
|-----|---------------------------------|-------------------------------------------------|-------------------------------------------------------------|-----------------------------------|--------------------------------------------------------------------------|------------------------------------------------|-------------------|----------------|
|     | RSPCK clock cycle               | Master                                          |                                                             | t <sub>SPcyc</sub>                | 2                                                                        | 4096                                           | t <sub>Pcyc</sub> | Figure 32.39   |
|     |                                 | Slave                                           |                                                             |                                   | 8                                                                        | 4096                                           | *1                |                |
|     | RSPCK clock<br>high pulse width | Master                                          |                                                             | t <sub>SPCKWH</sub>               | (t <sub>SPcyc</sub> - t <sub>SPCKr</sub> - t <sub>SPCKf</sub> )/2 - 3    | _                                              | ns                |                |
|     |                                 | Slave                                           |                                                             |                                   | (t <sub>SPcyc</sub> - t <sub>SPCKr</sub> - t <sub>SPCKf</sub> )/2        | _                                              |                   |                |
| - 1 | RSPCK clock<br>low pulse width  | Master                                          |                                                             | t <sub>SPCKWL</sub>               | (t <sub>SPcyc</sub> – t <sub>SPCKr</sub> –<br>t <sub>SPCKf</sub> )/2 – 3 | _                                              | ns                |                |
|     |                                 | Slave                                           |                                                             |                                   | (t <sub>SPcyc</sub> - t <sub>SPCKr</sub> - t <sub>SPCKf</sub> )/2        | _                                              |                   |                |
|     | RSPCK clock<br>rise/fall time   | Output                                          | 2.7 V or above                                              | t <sub>SPCKr,</sub>               | _                                                                        | 10                                             | ns                |                |
|     |                                 |                                                 | 1.8 V or above                                              | t <sub>SPCKf</sub>                | _                                                                        | 15<br>1                                        |                   |                |
|     |                                 | Input                                           |                                                             |                                   | _                                                                        |                                                | μs                |                |
| F   | Data input setup                | Master                                          | 2.7 V or above                                              | t <sub>SU</sub>                   | 10                                                                       | _                                              | ns                | Figure 32.40   |
|     | time                            |                                                 | 1.8 V or above                                              |                                   | 30                                                                       | _                                              |                   | Figure 32.45   |
|     |                                 | Slave                                           |                                                             | 1                                 | 25 – t <sub>Pcyc</sub>                                                   | _                                              |                   |                |
|     | Data input hold time            | Master                                          | RSPCK set to a division ratio other than PCLKB divided by 2 | t <sub>H</sub>                    | t <sub>Pcyc</sub>                                                        | _                                              | ns                |                |
|     |                                 |                                                 | RSPCK set to PCLKB divided by 2                             | t <sub>HF</sub>                   | 0                                                                        | _                                              |                   |                |
|     |                                 | Slave                                           | •                                                           | t <sub>H</sub>                    | 20 + 2 × t <sub>Pcyc</sub>                                               | _                                              |                   |                |
| ľ   | SSL setup time                  | me Master Slave                                 |                                                             | t <sub>LEAD</sub>                 | -30 + N*2 × t <sub>SPcyc</sub>                                           | _                                              | ns                |                |
|     |                                 |                                                 |                                                             |                                   | 2                                                                        | _                                              | t <sub>Pcyc</sub> |                |
| ľ   | SSL hold time                   | Master<br>Slave                                 |                                                             | t <sub>LAG</sub>                  | -30 + N*3 × t <sub>SPcyc</sub>                                           | _                                              | ns                |                |
|     |                                 |                                                 |                                                             |                                   | 2                                                                        | _                                              | t <sub>Pcyc</sub> |                |
| -   | Data output delay               | Master                                          | 2.7 V or above                                              | t <sub>OD</sub>                   | _                                                                        | 14                                             | ns                | 1              |
|     | time                            |                                                 | 1.8 V or above                                              | 1                                 | _                                                                        | 30                                             |                   |                |
|     |                                 | Slave                                           | 2.7 V or above                                              | 1                                 | _                                                                        | 3 × t <sub>Pcyc</sub> + 65                     |                   |                |
|     |                                 |                                                 | 1.8 V or above                                              |                                   | _                                                                        | 3 × t <sub>Pcyc</sub> +105                     |                   |                |
| ŀ   | Data output hold                | Master                                          | 2.7 V or above                                              | t <sub>OH</sub>                   | 0                                                                        | _                                              | ns                | †              |
|     | time                            |                                                 | 1.8 V or above                                              | 1                                 | -20                                                                      | _                                              |                   |                |
|     |                                 | Slave                                           | ı                                                           | 1                                 | 0                                                                        | _                                              |                   |                |
| l   | Successive                      | Master                                          |                                                             | t <sub>TD</sub>                   | t <sub>SPcyc</sub> + 2 × t <sub>Pcyc</sub>                               | 8 x t <sub>SPcyc</sub> + 2 x t <sub>Pcyc</sub> | ns                | †              |
|     | transmission delay<br>time      | Slave                                           |                                                             | 1                                 | 4 × t <sub>Pcyc</sub>                                                    | _                                              |                   |                |
|     | MOSI and MISO                   | Output                                          | 2.7 V or above                                              | t <sub>Dr</sub> , t <sub>Df</sub> | _                                                                        | 10                                             | ns                |                |
|     | rise/fall time                  |                                                 | 1.8 V or above                                              |                                   | _                                                                        | 20                                             |                   |                |
| ١   |                                 | Input                                           |                                                             |                                   | _                                                                        | 1                                              | μs                |                |
| ľ   | SSL rise/fall time              | Output                                          |                                                             | t <sub>SSLr,</sub>                | _                                                                        | 20                                             | ns                |                |
|     |                                 | Input                                           |                                                             | t <sub>SSLf</sub>                 | _                                                                        | 1                                              | μs                |                |
| ľ   | Slave access time               | <u>l '                                     </u> |                                                             | t <sub>SA</sub>                   | _                                                                        | 6                                              | t <sub>Pcyc</sub> | Figure 32.44   |
| l   |                                 |                                                 |                                                             | - SA                              | _                                                                        | 7                                              |                   | Figure 32.45   |
| ľ   | Slave output release            | time                                            | 2.7 V or above                                              | t <sub>REL</sub>                  | _                                                                        | 5                                              | t <sub>Pcyc</sub> | 1              |
|     |                                 |                                                 | 1.8 V or above                                              | 1                                 |                                                                          | 6                                              | 1                 |                |

Note 1. t<sub>Pcyc</sub>: PCLK cycle

Note 2. N: An integer from 1 to 8 that can be set by the RSPI clock delay register (SPCKD)

Note 3. N: An integer from 1 to 8 that can be set by the RSPI slave select negation delay register (SSLND)

Table 32.32 Timing of On-Chip Peripheral Modules (3)

|        | Item                            |                                         | Symbol              | Min. | Max.              | Unit*1             | Test Conditions |  |  |
|--------|---------------------------------|-----------------------------------------|---------------------|------|-------------------|--------------------|-----------------|--|--|
| Simple | SCK clock cycle output (master) |                                         | t <sub>SPcyc</sub>  | 4    | 65536             | t <sub>Pcyc</sub>  | Figure 32.39    |  |  |
| SPI    | SCK clock cycle input (slave)   |                                         |                     | 6    | 65536             |                    |                 |  |  |
|        | SCK clock high pulse width      |                                         | t <sub>SPCKWH</sub> | 0.4  | 0.6               | t <sub>SPcyc</sub> |                 |  |  |
|        | SCK clock low pulse width       |                                         | t <sub>SPCKWL</sub> | 0.4  | 0.6               | t <sub>SPcyc</sub> |                 |  |  |
|        | SCK clock rise/fall time        | t <sub>SPCKr</sub> , t <sub>SPCKf</sub> | _                   | 20   | ns                |                    |                 |  |  |
|        | Data input setup time (master)  | 2.7 V or above                          | t <sub>SU</sub>     | 65   | _                 | ns                 | Figure 32.40,   |  |  |
|        |                                 | 1.8 V or above                          |                     | 95   | _                 |                    | Figure 32.42    |  |  |
|        | Data input setup time (slave)   |                                         | 40                  | _    |                   |                    |                 |  |  |
|        | Data input hold time            | t <sub>H</sub>                          | 40                  | _    | ns                |                    |                 |  |  |
|        | SS input setup time             | t <sub>LEAD</sub>                       | 3                   | _    | t <sub>Pcyc</sub> |                    |                 |  |  |
|        | SS input hold time              | t <sub>LAG</sub>                        | 3                   | _    | t <sub>Pcyc</sub> |                    |                 |  |  |
|        | Data output delay time (master) | Data output delay time (master)         |                     |      | 40                | ns                 |                 |  |  |
|        | Data output delay time (slave)  | 2.7 V or above                          |                     | _    | 65                |                    |                 |  |  |
|        |                                 | 1.8 V or above                          |                     | _    | 85                |                    |                 |  |  |
|        | Data output hold time (master)  | 2.7 V or above                          | t <sub>OH</sub>     | -10  | _                 | ns                 |                 |  |  |
|        |                                 | 1.8 V or above                          |                     | -20  | _                 |                    |                 |  |  |
|        | Data output hold time (slave)   |                                         |                     | -10  | _                 |                    |                 |  |  |
|        | Data rise/fall time             | Data rise/fall time                     |                     |      | 20                | ns                 |                 |  |  |
|        | SS input rise/fall time         | t <sub>SSLr,</sub> t <sub>SSLf</sub>    | _                   | 20   | ns                |                    |                 |  |  |
|        | Slave access time               |                                         | t <sub>SA</sub>     | _    | 6                 | t <sub>Pcyc</sub>  | Figure 32.44,   |  |  |
|        | Slave output release time       |                                         | t <sub>REL</sub>    | _    | 6                 | t <sub>Pcyc</sub>  | Figure 32.45    |  |  |

Note 1. t<sub>Pcyc</sub>: PCLK cycle

Table 32.33 Timing of On-Chip Peripheral Modules (4)

|                        | Item                                      | Symbol            | Min.*1                              | Max.                        | Unit | Test Conditions |
|------------------------|-------------------------------------------|-------------------|-------------------------------------|-----------------------------|------|-----------------|
| RIIC                   | SCL0 input cycle time                     | t <sub>SCL</sub>  | 6 (12) × t <sub>IICcyc</sub> + 1300 | _                           | ns   | Figure 32.46    |
| (Standard mode, SMBus) | SCL0 input high pulse width               | t <sub>SCLH</sub> | 3 (6) × t <sub>IICcyc</sub> + 300   | _                           | ns   |                 |
| J240)                  | SCL0 input low pulse width                | t <sub>SCLL</sub> | 3 (6) × t <sub>IICcyc</sub> + 300   | _                           | ns   | ]               |
|                        | SCL0, SDA0 input rise time                | t <sub>Sr</sub>   | _                                   | 1000                        | ns   | ]               |
|                        | SCL0, SDA0 input fall time                | t <sub>Sf</sub>   | _                                   | 300                         | ns   |                 |
|                        | SCL0, SDA0 input spike pulse removal time | t <sub>SP</sub>   | 0                                   | 1 (4) × t <sub>IICcyc</sub> | ns   | ]               |
|                        | SDA0 input bus free time                  | t <sub>BUF</sub>  | 3 (6) × t <sub>IICcyc</sub> + 300   | _                           | ns   | ]               |
|                        | START condition input hold time           | t <sub>STAH</sub> | t <sub>IICcyc</sub> + 300           | _                           | ns   |                 |
|                        | Repeated START condition input setup time | t <sub>STAS</sub> | 1000                                | _                           | ns   |                 |
|                        | STOP condition input setup time           | t <sub>STOS</sub> | 1000                                | _                           | ns   | 1               |
|                        | Data input setup time                     | t <sub>SDAS</sub> | t <sub>IICcyc</sub> + 50            | _                           | ns   | ]               |
|                        | Data input hold time                      | t <sub>SDAH</sub> | 0                                   | _                           | ns   |                 |
|                        | SCL0, SDA0 capacitive load                | C <sub>b</sub>    | _                                   | 400                         | pF   |                 |
| RIIC                   | SCL0 input cycle time                     | t <sub>SCL</sub>  | 6 (12) × t <sub>IICcyc</sub> + 600  | _                           | ns   | Figure 32.46    |
| (Fast mode)            | SCL0 input high pulse width               | t <sub>SCLH</sub> | 3 (6) × t <sub>IICcyc</sub> + 300   | _                           | ns   |                 |
|                        | SCL0 input low pulse width                | t <sub>SCLL</sub> | 3 (6) × t <sub>IICcyc</sub> + 300   | _                           | ns   |                 |
|                        | SCL0, SDA0 input rise time                | t <sub>Sr</sub>   | *2                                  | 300                         | ns   |                 |
|                        | SCL0, SDA0 input fall time                | t <sub>Sf</sub>   | *2                                  | 300                         | ns   | ]               |
|                        | SCL0, SDA0 input spike pulse removal time | t <sub>SP</sub>   | 0                                   | 1 (4) × t <sub>IICcyc</sub> | ns   |                 |
|                        | SDA0 input bus free time                  | t <sub>BUF</sub>  | 3 (6) × t <sub>IICcyc</sub> + 300   | _                           | ns   |                 |
|                        | START condition input hold time           | t <sub>STAH</sub> | t <sub>IICcyc</sub> + 300           | _                           | ns   | ]               |
|                        | Repeated START condition input setup time | t <sub>STAS</sub> | 300                                 | _                           | ns   |                 |
|                        | STOP condition input setup time           | t <sub>STOS</sub> | 300                                 | _                           | ns   |                 |
|                        | Data input setup time                     | t <sub>SDAS</sub> | t <sub>IICcyc</sub> + 50            | _                           | ns   |                 |
|                        | Data input hold time                      | t <sub>SDAH</sub> | 0                                   | _                           | ns   |                 |
|                        | SCL0, SDA0 capacitive load                | C <sub>b</sub>    | _                                   | 400                         | pF   | 1               |

Note: t<sub>IICcyc</sub>: RIIC internal reference count clock (IICφ) cycle
Note 1. The value in parentheses is used when the ICMR3.NF[1:0] bits are set to 11b while a digital filter is enabled with the ICFER.NFE

Note 2. The minimum tsr and tsf specifications for fast mode are not set.

Table 32.34 Timing of On-Chip Peripheral Modules (5)

Conditions:  $2.7 \text{ V} \le \text{VCC} \le 3.6 \text{ V}, 2.7 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}, \text{VSS} = \text{AVSS0} = 0 \text{ V}, \text{fPCLKB} \le 32 \text{ MHz}, T_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

|                         | Item                                      | Symbol            | Min. | Max.                     | Unit | Test Conditions |
|-------------------------|-------------------------------------------|-------------------|------|--------------------------|------|-----------------|
| Simple I <sup>2</sup> C | SDA0 input rise time                      | t <sub>Sr</sub>   | _    | 1000                     | ns   | Figure 32.46    |
| (Standard mode)         | SDA0 input fall time                      | t <sub>Sf</sub>   | _    | 300                      | ns   |                 |
|                         | SDA0 input spike pulse removal time       | t <sub>SP</sub>   | 0    | 4 × t <sub>pcyc</sub> *1 | ns   |                 |
|                         | Data input setup time                     | t <sub>SDAS</sub> | 250  | _                        | ns   |                 |
|                         | Data input hold time                      | t <sub>SDAH</sub> | 0    | _                        | ns   |                 |
|                         | SCL0, SDA0 capacitive load                | C <sub>b</sub>    | _    | 400                      | pF   |                 |
| Simple I <sup>2</sup> C | SCL0, SDA0 input rise time                | t <sub>Sr</sub>   | _    | 300                      | ns   | Figure 32.46    |
| (Fast mode)             | SCL0, SDA0 input fall time                | t <sub>Sf</sub>   | _    | 300                      | ns   |                 |
|                         | SCL0, SDA0 input spike pulse removal time | t <sub>SP</sub>   | 0    | 4 × t <sub>pcyc</sub> *1 | ns   |                 |
|                         | Data input setup time                     | t <sub>SDAS</sub> | 100  | _                        | ns   |                 |
|                         | Data input hold time                      | t <sub>SDAH</sub> | 0    |                          | ns   |                 |
|                         | SCL0, SDA0 capacitive load                | C <sub>b</sub>    | _    | 400                      | pF   |                 |

Note:  $t_{Pcyc}$ : PCLK cycle Note 1. This applies when the SMR.CKS[1:0] bits = 00b and the SNFR.NFCS[2:0] bits = 010b while the SNFR.NFE bit = 1 and the digital filter is enabled.



Figure 32.32 I/O Port Input Timing



Figure 32.33 MTU2 Input/Output Timing



Figure 32.34 MTU2 Clock Input Timing



Figure 32.35 SCK Clock Input Timing



Figure 32.36 SCI Input/Output Timing: Clock Synchronous Mode



Figure 32.37 A/D Converter External Trigger Input Timing



Figure 32.38 CLKOUT Output Timing



Figure 32.39 RSPI Clock Timing and Simple SPI Clock Timing



Figure 32.40 RSPI Timing (Master, CPHA = 0) (Bit Rate: PCLKB Set to Division Ratio Other Than Divided by 2) and Simple SPI Timing (Master, CKPH = 1)



Figure 32.41 RSPI Timing (Master, CPHA = 0) (Bit Rate: PCLKB Set to Divided by 2)



Figure 32.42 RSPI Timing (Master, CPHA = 1) (Bit Rate: PCLKB Set to Division Ratio Other Than Divided by 2) and Simple SPI Timing (Master, CKPH = 0)



Figure 32.43 RSPI Timing (Master, CPHA = 1) (Bit Rate: PCLKB Set to Divided by 2)



Figure 32.44 RSPI Timing (Slave, CPHA = 0) and Simple SPI Timing (Slave, CKPH = 1)



Figure 32.45 RSPI Timing (Slave, CPHA = 1) and Simple SPI Timing (Slave, CKPH = 0)

RX110 Group 32. Electrical Characteristics



Figure 32.46 RIIC Bus Interface Input/Output Timing and Simple I<sup>2</sup>C Bus Interface Input/Output Timing

## 32.4 A/D Conversion Characteristics

Table 32.35 A/D Conversion Characteristics (1)

Conditions:  $2.7 \text{ V} \le \text{VCC} \le 3.6 \text{ V}, 2.7 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}, 2.7 \text{ V} \le \text{VREFH0} \le \text{AVCC0}, \text{VSS} = \text{AVSS0} = \text{VREFL0} = 0 \text{ V}, T_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

|                                                       | Item                                                               | Min.                           | Тур.  | Max.   | Unit | Test Conditions                                                                |
|-------------------------------------------------------|--------------------------------------------------------------------|--------------------------------|-------|--------|------|--------------------------------------------------------------------------------|
| Frequency                                             |                                                                    | 4                              | _     | 32     | MHz  |                                                                                |
| Resolution                                            |                                                                    | _                              | _     | 12     | Bit  |                                                                                |
| Conversion time*1<br>(Operation at<br>PCLKD = 32 MHz) | Permissible signal source impedance (Max.) = $0.3 \text{ k}\Omega$ | 1.031<br>(0.313)* <sup>2</sup> | ı     | _      | μs   | High-precision channel<br>ADCSR.ADHSC bit = 1<br>ADSSTRn.SST[7:0] bits = 09h   |
|                                                       |                                                                    | 1.375<br>(0.641)* <sup>2</sup> | -     |        |      | Normal-precision channel<br>ADCSR.ADHSC bit = 1<br>ADSSTRn.SST[7:0] bits = 14h |
| Analog input effective range                          |                                                                    | 0                              | _     | VREFH0 | V    |                                                                                |
| Offset error                                          |                                                                    | _                              | ±0.5  | ±4.5   | LSB  | High-precision channel PJ6PFS.ASEL bit = 1 PJ7PFS.ASEL bit = 1                 |
|                                                       |                                                                    |                                |       | ±6.0   | LSB  | Other than above                                                               |
| Full-scale error                                      |                                                                    | _                              | ±0.75 | ±4.5   | LSB  | High-precision channel PJ6PFS.ASEL bit = 1 PJ7PFS.ASEL bit = 1                 |
|                                                       |                                                                    |                                |       | ±6.0   | LSB  | Other than above                                                               |
| Quantization error                                    |                                                                    | _                              | ±0.5  | _      | LSB  |                                                                                |
| Absolute accuracy                                     |                                                                    | _                              | ±1.25 | ±5.0   | LSB  | High-precision channel PJ6PFS.ASEL bit = 1 PJ7PFS.ASEL bit = 1                 |
|                                                       |                                                                    |                                |       | ±8.0   | LSB  | Other than above                                                               |
| DNL differential nonli                                | nearity error                                                      | _                              | ±1.0  | _      | LSB  |                                                                                |
| INL integral nonlinea                                 | rity error                                                         | _                              | ±1.0  | ±3.0   | LSB  |                                                                                |

Note: The characteristics apply when no pin functions other than A/D converter input are used. Absolute accuracy includes quantization errors. Offset error, full-scale error, DNL differential nonlinearity error, and INL integral nonlinearity error do not include quantization errors.

Note 1. The conversion time is the sum of the sampling time and the comparison time. As the test conditions, the number of sampling states is indicated.

Note 2. The value in parentheses indicates the sampling time.



Figure 32.47 AVCC0 to AVREFH Voltage Range

#### Table 32.36 A/D Conversion Characteristics (2)

Conditions:  $2.4 \text{ V} \le \text{VCC} \le 3.6 \text{ V}, 2.4 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}, 2.4 \text{ V} \le \text{VREFH0} \le \text{AVCC0}, \text{VSS} = \text{AVSS0} = \text{VREFL0} = 0 \text{ V}, T_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

|                                                       | Item                                                | Min.                           | Тур.  | Max.   | Unit | Test Conditions                                                                |
|-------------------------------------------------------|-----------------------------------------------------|--------------------------------|-------|--------|------|--------------------------------------------------------------------------------|
| Frequency                                             |                                                     | 4                              | _     | 16     | MHz  |                                                                                |
| Resolution                                            |                                                     | _                              | _     | 12     | Bit  |                                                                                |
| Conversion time*1<br>(Operation at<br>PCLKD = 16 MHz) | Permissible signal source impedance (Max.) = 1.0 kΩ | 2.062<br>(0.625)* <sup>2</sup> | _     | _      | μs   | High-precision channel<br>ADCSR.ADHSC bit = 1<br>ADSSTRn.SST[7:0] bits = 09h   |
|                                                       |                                                     | 2.750<br>(1.313)* <sup>2</sup> | _     | _      | μs   | Normal-precision channel<br>ADCSR.ADHSC bit = 1<br>ADSSTRn.SST[7:0] bits = 14h |
| Analog input effective                                | range                                               | 0                              | _     | VREFH0 | V    |                                                                                |
| Offset error                                          |                                                     | _                              | ±0.5  | ±6.0   | LSB  |                                                                                |
| Full-scale error                                      |                                                     | _                              | ±1.25 | ±6.0   | LSB  |                                                                                |
| Quantization error                                    |                                                     | _                              | ±0.5  | _      | LSB  |                                                                                |
| Absolute accuracy                                     |                                                     | _                              | ±3.0  | ±8.0   | LSB  |                                                                                |
| DNL differential nonli                                | nearity error                                       | _                              | ±1.0  | _      | LSB  |                                                                                |
| INL integral nonlinear                                | rity error                                          | _                              | ±1.5  | ±3.0   | LSB  |                                                                                |

Note: The characteristics apply when no pin functions other than A/D converter input are used. Absolute accuracy includes quantization errors. Offset error, full-scale error, DNL differential nonlinearity error, and INL integral nonlinearity error do not include quantization errors.

Note 1. The conversion time is the sum of the sampling time and the comparison time. As the test conditions, the number of sampling states is indicated.

Note 2. The value in parentheses indicates the sampling time.

#### Table 32.37 A/D Conversion Characteristics (3)

Conditions: 1.8 V  $\leq$  VCC  $\leq$  3.6 V, 1.8 V  $\leq$  AVCC0  $\leq$  3.6 V, 1.8 V  $\leq$  VREFH0  $\leq$  AVCC0, VSS = AVSS0 = VREFL0 = 0 V,  $T_a = -40$  to +105°C

|                                                      | Item                                                | Min.                           | Тур.  | Max.   | Unit | Test Conditions                                                                |
|------------------------------------------------------|-----------------------------------------------------|--------------------------------|-------|--------|------|--------------------------------------------------------------------------------|
| Frequency                                            |                                                     | 1                              | _     | 8      | MHz  |                                                                                |
| Resolution                                           |                                                     | _                              | _     | 12     | Bit  |                                                                                |
| Conversion time*1<br>(Operation at<br>PCLKD = 8 MHz) | Permissible signal source impedance (Max.) = 5.0 kΩ | 4.875<br>(1.250)* <sup>2</sup> | _     | _      | μs   | High-precision channel<br>ADCSR.ADHSC bit = 0<br>ADSSTRn.SST[7:0] bits = 09h   |
|                                                      |                                                     | 6.250<br>(2.625)* <sup>2</sup> | _     | _      |      | Normal-precision channel<br>ADCSR.ADHSC bit = 0<br>ADSSTRn.SST[7:0] bits = 14h |
| Analog input effective                               | e range                                             | 0                              | _     | VREFH0 | V    |                                                                                |
| Offset error                                         |                                                     | _                              | ±0.5  | ±24.0  | LSB  |                                                                                |
| Full-scale error                                     |                                                     | _                              | ±1.25 | ±24.0  | LSB  |                                                                                |
| Quantization error                                   |                                                     | _                              | ±0.5  | _      | LSB  |                                                                                |
| Absolute accuracy                                    |                                                     | _                              | ±2.75 | ±32.0  | LSB  |                                                                                |
| DNL differential nonlinearity error                  |                                                     | _                              | ±1.0  | _      | LSB  |                                                                                |
| INL integral nonlinear                               | rity error                                          | _                              | ±1.25 | ±12.0  | LSB  |                                                                                |

Note: The characteristics apply when no pin functions other than A/D converter input are used. Absolute accuracy includes quantization errors. Offset error, full-scale error, DNL differential nonlinearity error, and INL integral nonlinearity error do not include quantization errors.

Note 1. The conversion time is the sum of the sampling time and the comparison time. As the test conditions, the number of sampling states is indicated.

Note 2. The value in parentheses indicates the sampling time.

#### Table 32.38 A/D Converter Channel Classification

| Classification                           | Channel                    | Conditions           | Remarks                                                             |
|------------------------------------------|----------------------------|----------------------|---------------------------------------------------------------------|
| High-precision channel                   | AN000 to AN004, AN006      | AVCC0 = 1.8 to 3.6 V | Pins AN000 to AN004 and AN006                                       |
| Normal-precision channel                 | AN008 to AN015             |                      | cannot be used as digital outputs when the A/D converter is in use. |
| Internal reference voltage input channel | Internal reference voltage | AVCC0 = 2.0 to 3.6 V |                                                                     |
| Temperature sensor input channel         | Temperature sensor output  | AVCC0 = 2.0 to 3.6 V |                                                                     |

## Table 32.39 A/D Internal Reference Voltage Characteristics

Conditions:  $2.0 \text{ V} \leq \text{VCC} \leq 3.6 \text{ V}, 2.0 \text{ V} \leq \text{AVCC0} \leq 3.6 \text{ V}^{*1}, \text{ VSS} = \text{AVSS0} = \text{VREFL0} = 0 \text{ V}, \text{ T}_a = -40 \text{ to } +105^{\circ}\text{C}$ 

| Item                                       | Min. | Тур. | Max. | Unit | Test Conditions |
|--------------------------------------------|------|------|------|------|-----------------|
| Internal reference voltage input channel*2 | 1.36 | 1.43 | 1.50 | V    |                 |

Note 1. The internal reference voltage cannot be selected for input channels when AVCC0 < 2.0  $\rm V.$ 

Note 2. The A/D internal reference voltage indicates the voltage when the internal reference voltage is input to the A/D converter.



Figure 32.48 Illustration of A/D Converter Characteristic Terms

#### **Absolute accuracy**

Absolute accuracy is the difference between output code based on the theoretical A/D conversion characteristics, and the actual A/D conversion result. When measuring absolute accuracy, the voltage at the midpoint 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 12-bit resolution is used and if reference voltage (VREFH0 = 3.072 V), then 1-LSB width becomes 0.75 mV, and 0 mV, 0.75 mV, 1.5 mV, ... are used as analog input voltages.

If analog input voltage is 6 mV, absolute accuracy =  $\pm 5$  LSB means that the actual A/D conversion result is in the range of 003h to 00Dh though an output code, 008h, can be expected from the theoretical A/D conversion characteristics.

#### Integral nonlinearity error (INL)

Integral nonlinearity error is the maximum deviation between the ideal line when the measured offset and full-scale errors are zeroed, and the actual output code.



#### Differential nonlinearity error (DNL)

Differential nonlinearity error is the difference between 1-LSB width based on the ideal A/D conversion characteristics and the width of the actually output code.

#### Offset error

Offset error is the difference between a transition point of the ideal first output code and the actual first output code.

#### Full-scale error

Full-scale error is the difference between a transition point of the ideal last output code and the actual last output code.

## 32.5 Temperature Sensor Characteristics

Table 32.40 Temperature Sensor Characteristics

Conditions:  $2.0 \text{ V} \le \text{VCC} \le 3.6 \text{ V}, 2.0 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}, \text{VSS} = \text{AVSS0} = 0 \text{ V}, \text{T}_a = -40 \text{ to } +105^{\circ}\text{C}$ 

| Item                          | Symbol             | Min. | Тур.  | Max. | Unit  | Test Conditions |
|-------------------------------|--------------------|------|-------|------|-------|-----------------|
| Relative accuracy             | _                  | _    | ±1.5  | _    | °C    | 2.4 V or above  |
|                               |                    | _    | ±2.0  | _    |       | Below 2.4 V     |
| Temperature slope             | _                  | _    | -3.65 | _    | mV/°C |                 |
| Output voltage (at 25°C)      | _                  | _    | 1.05  | _    | V     | VCC = 3.3 V     |
| Temperature sensor start time | t <sub>START</sub> | _    | _     | 5    | μs    |                 |
| Sampling time                 | _                  | 5    | _     | _    | μs    | ]               |

## 32.6 Power-On Reset Circuit and Voltage Detection Circuit Characteristics

Table 32.41 Power-On Reset Circuit and Voltage Detection Circuit Characteristics (1)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

| It                      | em                        | Symbol              | Min. | Тур. | Max. | Unit | Test Conditions               |
|-------------------------|---------------------------|---------------------|------|------|------|------|-------------------------------|
| Voltage detection level | Power-on reset (POR)      | $V_{POR}$           | 1.35 | 1.50 | 1.65 | V    | Figure 32.49,<br>Figure 32.50 |
|                         | Voltage detection circuit | V <sub>det1_4</sub> | 3.00 | 3.10 | 3.20 | V    | Figure 32.51                  |
|                         | (LVD1)* <sup>1</sup>      | V <sub>det1_5</sub> | 2.91 | 3.00 | 3.09 |      | At falling edge VCC           |
|                         |                           | V <sub>det1_6</sub> | 2.81 | 2.90 | 2.99 |      |                               |
|                         | V <sub>det1_7</sub>       | 2.70                | 2.79 | 2.88 | 1    |      |                               |
|                         |                           | V <sub>det1_8</sub> | 2.60 | 2.68 | 2.76 |      |                               |
|                         |                           | V <sub>det1_9</sub> | 2.50 | 2.58 | 2.66 |      |                               |
|                         |                           | V <sub>det1_A</sub> | 2.40 | 2.48 | 2.56 |      |                               |
|                         |                           | V <sub>det1_B</sub> | 1.99 | 2.06 | 2.13 |      |                               |
|                         |                           | V <sub>det1_C</sub> | 1.90 | 1.96 | 2.02 |      |                               |
|                         |                           | V <sub>det1_D</sub> | 1.80 | 1.86 | 1.92 |      |                               |

Note: These characteristics apply when noise is not superimposed on the power supply. When a setting is made so that the voltage detection level overlaps with that of the voltage detection circuit (LVD2), it cannot be specified which of LVD1 and LVD2 is used for voltage detection.

Note 1. n in the symbol Vdet1\_n denotes the value of the LVDLVLR.LVD1LVL[3:0] bits.

Table 32.42 Power-On Reset Circuit and Voltage Detection Circuit Characteristics (2)

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

|                                            | Item                                           | Symbol                 | Min. | Тур. | Max. | Unit                                       | Test Conditions                            |  |
|--------------------------------------------|------------------------------------------------|------------------------|------|------|------|--------------------------------------------|--------------------------------------------|--|
| Voltage detection level                    | Voltage detection circuit                      | V <sub>det2_0</sub>    | 2.71 | 2.90 | 3.09 | V                                          | Figure 32.52                               |  |
|                                            | (LVD2)*1                                       | V <sub>det2_1</sub>    | 2.43 | 2.60 | 2.77 |                                            | At falling edge VCC                        |  |
|                                            |                                                | V <sub>det2_2</sub>    | 1.87 | 2.00 | 2.13 |                                            |                                            |  |
|                                            |                                                | V <sub>det2_3</sub> *2 | 1.69 | 1.80 | 1.91 |                                            |                                            |  |
| Wait time after power-on                   | At normal startup*3                            | t <sub>POR</sub>       | _    | 9.1  | _    | ms                                         | Figure 32.50                               |  |
| reset cancellation                         | During fast startup time*4                     | t <sub>POR</sub>       | _    | 1.6  | _    |                                            |                                            |  |
| Wait time after voltage monitoring 1 reset | Power-on voltage monitoring 1 reset disabled*3 | t <sub>LVD1</sub>      | _    | 568  | _    | μs                                         | Figure 32.51                               |  |
| cancellation                               | Power-on voltage monitoring 1 reset enabled*4  |                        | _    | 100  | _    |                                            |                                            |  |
| Wait time after voltage mo                 | nitoring 2 reset cancellation                  | t <sub>LVD2</sub>      | _    | 100  | _    | μs                                         | Figure 32.52                               |  |
| Response delay time                        |                                                | t <sub>det</sub>       | _    | _    | 350  | μs                                         | Figure 32.49                               |  |
| Minimum VCC down time*                     | 5                                              | t <sub>VOFF</sub>      | 350  | _    | _    | μs                                         | Figure 32.49,<br>VCC = 1.0 V or above      |  |
| Power-on reset enable tim                  | е                                              | t <sub>W(POR)</sub>    | 1    | _    | _    | ms                                         | Figure 32.50,<br>VCC = below 1.0 V         |  |
| LVD operation stabilization                | time (after LVD is enabled)                    | Td <sub>(E-A)</sub>    | _    | _    | 300  | μs                                         | Figure 32.51, Figure 32.52                 |  |
| Hysteresis width (LVD1 an                  | d LVD2)                                        | $V_{LVH}$              | _    | 70   | _    | mV                                         | Vdet1_4 selected                           |  |
|                                            |                                                |                        | _    | 60   | _    |                                            | Vdet1_5 to 9, LVD2 selected                |  |
|                                            |                                                | _                      | 50   | _    | 1    | When selection is from among Vdet1_A to B. |                                            |  |
|                                            |                                                |                        | _    | 40   | _    |                                            | When selection is from among Vdet1_C to D. |  |

Note: These characteristics apply when noise is not superimposed on the power supply. When a setting is made so that the voltage detection level overlaps with that of the voltage detection circuit (LVD1), it cannot be specified which of LVD1 and LVD2 is used for voltage detection.

Note 1. n in the symbol Vdet2\_n denotes the value of the LVDLVLR.LVD2LVL[3:0] bits.

Note 2. Vdet2\_3 selection can be used only when the CMPA2 pin input voltage is selected and cannot be used when the power supply voltage (VCC) is selected.

Note 3. When OFS1.(STUPLVD1REN, FASTSTUP) = 11b.

Note 4. When OFS1.(STUPLVD1REN, FASTSTUP) ≠ 11b.

Note 5. The minimum VCC down time indicates the time when VCC is below the minimum value of voltage detection levels V<sub>POR</sub>, V<sub>det0</sub>, V<sub>det1</sub>, and V<sub>det2</sub> for the POR/LVD.





Figure 32.49 Voltage Detection Reset Timing



Figure 32.50 Power-On Reset Timing



Figure 32.51 Voltage Detection Circuit Timing (V<sub>det1</sub>)



Figure 32.52 Voltage Detection Circuit Timing (V<sub>det2</sub>)

# 32.7 Oscillation Stop Detection Timing

## **Table 32.43 Oscillation Stop Detection Circuit Characteristics**

Conditions:  $1.8 \text{ V} \le \text{VCC} \le 3.6 \text{ V}$ ,  $1.8 \text{ V} \le \text{AVCC0} \le 3.6 \text{ V}$ , VSS = AVSS0 = 0 V,  $\text{T}_a = -40 \text{ to } +105 ^{\circ}\text{C}$ 

| Item           | Symbol          | Min. | Тур. | Max. | Unit | Test<br>Conditions |
|----------------|-----------------|------|------|------|------|--------------------|
| Detection time | t <sub>dr</sub> | _    | _    | 1    | ms   | Figure 32.53       |



Figure 32.53 Oscillation Stop Detection Timing

## 32.8 ROM (Flash Memory for Code Storage) Characteristics

Table 32.44 ROM (Flash Memory for Code Storage) Characteristics (1)

| Item                                                |  | Symbol           | Min.     | Тур. | Max. | Unit  | Conditions             |
|-----------------------------------------------------|--|------------------|----------|------|------|-------|------------------------|
| Reprogramming/erasure cycle*1                       |  | N <sub>PEC</sub> | 1000     | _    | _    | Times |                        |
| Data hold time After 1000 times of N <sub>PEC</sub> |  | t <sub>DRP</sub> | 20*2, *3 | _    | _    | Year  | T <sub>a</sub> = +85°C |

Note 1. Definition of reprogram/erase cycle: The reprogram/erase cycle is the number of erasing for each block. When the reprogram/erase cycle is n times (n = 1000), erasing can be performed n times for each block. For instance, when 4-byte programming is performed 256 times for different addresses in 1-Kbyte block and then the entire block is erased, the reprogram/erase cycle is counted as one. However, programming the same address for several times as one erasing is not enabled (overwriting is prohibited).

Note 2. Characteristic when using the flash memory programmer and the self-programming library provided from Renesas Electronics.

Note 3. This result is obtained from reliability testing.

#### Table 32.45 ROM (Flash Memory for Code Storage) Characteristics (2)

High-speed operating mode Conditions:  $2.7 \text{ V} \leq \text{VCC} \leq 3.6 \text{ V}, 2.7 \text{ V} \leq \text{AVCC0} \leq 3.6 \text{ V}, \text{VSS} = \text{AVSS0} = 0 \text{ V}$ 

Temperature range for the programming/erasure operation:  $T_a = -40$  to +105°C

| Item                            |             | Cumbal             | FCL  | K = 1 MHz |      | FCL  | ( = 32 MHz |       | Unit  |
|---------------------------------|-------------|--------------------|------|-----------|------|------|------------|-------|-------|
| item                            |             | Symbol             | Min. | Тур.      | Max. | Min. | Тур.       | Max.  | Offic |
| Programming time                | 4-byte      | t <sub>P4</sub>    | _    | 103       | 931  | _    | 52         | 489   | μs    |
| Erasure time                    | 1-Kbyte     | t <sub>E1K</sub>   | _    | 8.23      | 267  | _    | 5.48       | 214   | ms    |
|                                 | 128-Kbyte   | t <sub>E128K</sub> | _    | 203       | 463  | _    | 20         | 228   | ms    |
| Blank check time                | 4-byte      | t <sub>BC4</sub>   | _    | _         | 48   | _    | _          | 15.9  | μs    |
|                                 | 1-Kbyte     | t <sub>BC1K</sub>  | _    | _         | 1.58 | _    | _          | 0.127 | ms    |
| Erase operation forcible s      | stop time   | t <sub>SED</sub>   | _    | _         | 21.6 | _    | _          | 12.8  | μs    |
| Start-up area switching so      | etting time | t <sub>SAS</sub>   | _    | 12.6      | 543  | _    | 6.16       | 432   | ms    |
| Access window time              |             | t <sub>AWS</sub>   | _    | 12.6      | 543  | _    | 6.16       | 432   | ms    |
| ROM mode transition wait time 1 |             | t <sub>DIS</sub>   | 2    | _         | _    | 2    | _          | _     | μs    |
| ROM mode transition was         | it time 2   | t <sub>MS</sub>    | 5    | _         | _    | 5    | _          | _     | μs    |

Note: Does not include the time until each operation of the flash memory is started after instructions are executed by software.

Note: The lower-limit frequency of FCLK is 1 MHz during programming or erasing of the flash memory. When using FCLK at below

4 MHz, the frequency can be set to 1 MHz, 2 MHz, or 3 MHz. A non-integer frequency such as 1.5 MHz cannot be set.

Note: The frequency accuracy of FCLK should be ±3.5%. Confirm the frequency accuracy of the clock source.

#### Table 32.46 ROM (Flash Memory for Code Storage) Characteristics (3)

Middle-speed operating mode Conditions: 1.8  $V \le VCC \le 3.6 V$ , 1.8  $V \le AVCC0 \le 3.6 V$ , VSS = AVSS0 = 0 V

Temperature range for the programming/erasure operation:  $T_a = -40$  to  $+85^{\circ}$ C

| Item                            |                    | Symbol             | FC   | LK = 1 MH | łz   |      | FCLK = | 8 MHz | Unit    |
|---------------------------------|--------------------|--------------------|------|-----------|------|------|--------|-------|---------|
| item                            |                    | Symbol             | Min. | Тур.      | Max. | Min. | Тур.   | Max.  | ] 01111 |
| Programming time                | 4-byte             | t <sub>P4</sub>    | _    | 143       | 1330 | _    | 96.8   | 932   | μs      |
| Erasure time                    | 1-Kbyte            | t <sub>E1K</sub>   | _    | 8.3       | 269  | _    | 5.85   | 219   | ms      |
|                                 | 128-Kbyte          | t <sub>E128K</sub> | _    | 203       | 464  | _    | 40     | 260   | ms      |
| Blank check time                | 4-byte             | t <sub>BC4</sub>   | _    | _         | 78   | _    | _      | 50    | μs      |
|                                 | 1-Kbyte            | t <sub>BC1K</sub>  | _    | _         | 1.61 | _    | _      | 0.369 | ms      |
| Erase operation forcible        | stop time          | t <sub>SED</sub>   | _    | _         | 33.6 | _    | _      | 25.6  | μs      |
| Start-up area switching s       | etting time        | t <sub>SAS</sub>   | _    | 13.2      | 549  | _    | 7.6    | 445   | ms      |
| Access window time              | Access window time |                    | _    | 13.2      | 549  | _    | 7.6    | 445   | ms      |
| ROM mode transition wait time 1 |                    | t <sub>DIS</sub>   | 2    | _         | _    | 2    | _      | _     | μs      |
| ROM mode transition wa          | it time 2          | t <sub>MS</sub>    | 3    | _         | _    | 3    | _      | _     | μs      |

Note: Does not include the time until each operation of the flash memory is started after instructions are executed by software.

Note: The lower-limit frequency of FCLK is 1 MHz during programming or erasing of the flash memory. When using FCLK at below

4 MHz, the frequency can be set to 1 MHz, 2 MHz, or 3 MHz. A non-integer frequency such as 1.5 MHz cannot be set.

Note: The frequency accuracy of FCLK should be ±3.5%. Confirm the frequency accuracy of the clock source.

## 32.9 Usage Notes

### 32.9.1 Connecting VCL Capacitor and Bypass Capacitors

This MCU integrates an internal voltage-down circuit, which is used for lowering the power supply voltage in the internal MCU to adjust automatically to the optimum level. A 4.7- $\mu$ F capacitor needs to be connected between this internal voltage-down power supply (VCL pin) and VSS pin. Figure 32.54 to Figure 32.55 shows how to connect external capacitors. Place an external capacitor close to the pins. Do not apply the power supply voltage to the VCL pin. Insert a multilayer ceramic capacitor as a bypass capacitor between each pair of the power supply pins. Implement a bypass capacitor to the MCU power supply pins as close as possible. Use a recommended value of 0.1  $\mu$ F as the capacitance of the capacitors. For the capacitors related to crystal oscillation, see section 9, Clock Generation Circuit. For the capacitors related to analog modules, also see section 27, 12-Bit A/D Converter (S12ADb). For notes on designing the printed circuit board, see the descriptions of the application note "Hardware Design Guide" (R01AN1411EJ). The latest version can be downloaded from Renesas Electronics Website.



Figure 32.54 Connecting Capacitors (64 Pins)



Figure 32.55 Connecting Capacitors (48-pin LFQFP)

# Appendix 1. Port States in Each Processing Mode

Table 1.1 Port States in Each Processing State

| Port Name (Pin Name) | Reset |                      | andby Mode        |
|----------------------|-------|----------------------|-------------------|
| P03                  | Hi-Z  |                      | ep-O              |
| P05                  | Hi-Z  | Kee                  |                   |
| P14 (IRQ4)           | Hi-Z  | Keep                 | o-0* <sup>1</sup> |
| P15 (IRQ5/CLKOUT)    | Hi-Z  | CLKOUT selected      | CLKOUT output     |
|                      |       | Other than the above | Keep-O*1          |
| P16 (IRQ6/RTCOUT)    | Hi-Z  | RTCOUT selected      | RTCOUT output     |
|                      |       | Other than the above | Keep-O*1, *2      |
| P17 (IRQ7)           | Hi-Z  |                      | o-O*1             |
| P26                  | Hi-Z  | Kee                  |                   |
| P27 (IRQ3)           | Hi-Z  | Keep                 |                   |
| P30 (IRQ0)           | Hi-Z  | Keep                 |                   |
| P31 (IRQ1)           | Hi-Z  | Keep                 | o-O* <sup>1</sup> |
| P32 (IRQ2/RTCOUT)    | Hi-Z  | RTCOUT selected      | RTCOUT output     |
|                      |       | Other than the above | Keep-O*1          |
| P35 (NMI)            | Hi-Z  | Kee                  | P*1               |
| P40 to P44, P46      | Hi-Z  | Kee                  | •                 |
| P54, P55             | Hi-Z  | Kee                  |                   |
| PA0                  | Hi-Z  | Kee                  | •                 |
| PA1 (RTCOUT)         | Hi-Z  | RTCOUT selected      | RTCOUT output     |
|                      |       | Other than the above | Keep-O            |
| PA3 (IRQ6)           | Hi-Z  | Keep                 |                   |
| PA4 (IRQ5)           | Hi-Z  |                      | o-0* <sup>1</sup> |
| PA6 (IRQ3)           | Hi-Z  | Keep                 | o-O* <sup>1</sup> |
| PB0 (IRQ2/RTCOUT)    | Hi-Z  | RTCOUT selected      | RTCOUT output     |
|                      |       | Other than the above | Keep-O*1          |
| PB1 (IRQ4)           | Hi-Z  | Keep                 | o-O* <sup>1</sup> |
| PB3                  | Hi-Z  | Kee                  |                   |
| PB5 to PB7           | Hi-Z  | Kee                  | •                 |
| PC2, PC3             | Hi-Z  | Kee                  | •                 |
| PC4 (IRQ2/CLKOUT)    | Hi-Z  | CLKOUT selected      | CLKOUT output     |
|                      |       | Other than the above | Keep-O*1          |
| PC5                  | Hi-Z  | Kee                  | p-O               |
| PC6                  | Hi-Z  |                      | ep-O              |
| PC7                  | Hi-Z  |                      | ep-O              |
| PE0 (IRQ0)           | Hi-Z  | Keep                 |                   |
| PE1 (IRQ1)           | Hi-Z  | Keep                 |                   |
| PE2 (IRQ7)           | Hi-Z  | Keep                 |                   |
| PE3 (IRQ3)           | Hi-Z  |                      | o-0* <sup>1</sup> |
| PE4 (IRQ4)           | Hi-Z  | Keep                 |                   |
| PE5 (IRQ5)           | Hi-Z  |                      | o-O* <sup>1</sup> |
| PE6 (IRQ6)           | Hi-Z  |                      | o-O* <sup>1</sup> |
| PE7 (IRQ7)           | Hi-Z  |                      | o-0* <sup>1</sup> |
| PH0                  | Hi-Z  |                      | ep-O              |
| PH1(IRQ0)            | Hi-Z  |                      | o-0* <sup>1</sup> |
| PH2(IRQ1)            | Hi-Z  | Keep                 | o-O* <sup>1</sup> |
| PH3                  | Hi-Z  | Kee                  | ep-O              |
| PH7                  | Hi-Z  | Ke                   | ер                |
| PJ6                  | Hi-Z  | Kee                  | ер-О              |
| PJ7                  | Hi-Z  | Kee                  | ep-O              |

H: High level

Keep-O: Output pins retain their previous values, and input pins become high-impedance.

Keep: Pin states are retained during periods in software standby mode. (pull-up and open-drain settings are also retained.)

Hi-Z: High-impedance

Note 1. Input is enabled if the pin is specified as the software standby mode canceling source while it is used as an external interrupt pin.

Note 2. Do not input or output a high-level signal in software standby mode if the pin is selected as a peripheral function or external interrupt pin.



# Appendix 2. Package Dimensions

Information on the latest version of the package dimensions or mountings has been displayed in "Packages" on Renesas Electronics Corporation website.



Figure A 64-Pin LFQFP (PLQP0064KB-A)



Figure B 64-Pin LQFP (PLQP0064GA-A)



Figure C 64-Pin WFLGA (PWLG0064KA-A)



Figure D 48-Pin LFQFP (PLQP0048KB-A)



Figure E 48-Pin HWQFN (PWQN0048KB-A)



Figure F 40-Pin HWQFN (PWQN0040KC-A)



Figure G 36-Pin WFLGA (PWLG0036KA-A)

| REVISION HISTORY | RX110 Group User's Manual: Hardware |
|------------------|-------------------------------------|
|------------------|-------------------------------------|

## Classifications

- Items with Technical Update document number: Changes according to the corresponding issued Technical Update
- Items without Technical Update document number: Minor changes that do not require Technical Update to be issued

| Rev. | Date         |                     | Description                                                                             | Classification |
|------|--------------|---------------------|-----------------------------------------------------------------------------------------|----------------|
|      |              | Page                | Summary                                                                                 | 0.00000        |
| 1.00 | Dec 20, 2013 | _                   | First edition, issued                                                                   |                |
| 1.10 | Dec 10, 2014 | 1. Overview         |                                                                                         |                |
|      |              | 33 to 35            | Table 1.1 Outline of Specifications: I/O ports changed and Unique ID added              |                |
|      |              | 46                  | Figure 1.5 Pin Assignments of the 48-Pin LFQFP/HWQFN: Note added                        |                |
|      |              | 47                  | Figure 1.6 Pin Assignments of the 40-Pin HWQFN: Note added                              |                |
|      |              | 5. I/O Regist       | ers                                                                                     |                |
|      |              | 92 to 104           | Table 5.1 List of I/O Registers (Address Order), changed                                | TN-RX*-A113A/E |
|      |              | 7. Option-Se        | tting Memory                                                                            |                |
|      |              | 118                 | 7.2.1 Option Function Select Register 0 (OFS0): Bit function table changed              |                |
|      |              | 9. Clock Ger        | neration Circuit                                                                        |                |
|      |              | 162                 | 9.6 Internal Clock, changed                                                             |                |
|      |              | 164                 | Figure 9.9 Example of Initialization Flowchart When Sub-Clock is Used as                |                |
|      |              |                     | Count Source of Realtime Clock, changed                                                 |                |
|      |              | 165                 | Figure 9.10 Example of Initialization Flowchart When Sub-Clock is Used                  |                |
|      |              |                     | Only as Count Source of Realtime Clock, changed                                         |                |
|      |              | 166                 | Figure 9.11 Example of Initialization Flowchart When Sub-Clock is Used                  |                |
|      |              |                     | Only as System Clock, changed                                                           |                |
|      |              | 11. Low Pow         | er Consumption                                                                          |                |
|      |              | 197                 | 11.6.1.1 Entry to Sleep Mode: Note 2 added                                              |                |
|      |              | 199                 | 11.6.2.1 Entry to Deep Sleep Mode: Note 2 added                                         |                |
|      |              | 201                 | 11.6.3.1 Entry to Software Standby Mode: Note 2 added                                   |                |
|      |              | 14. Interrupt       | Controller (ICUb)                                                                       |                |
|      |              | 216                 | 14. Interrupt Controller (ICUb): PCLKB description added                                |                |
|      |              | 16. Data Tra        | nsfer Controller (DTCa)                                                                 |                |
|      |              | 288                 | 16.6.2 Chain Transfer When the Counter = 0, changed                                     |                |
|      |              | 17. I/O Ports       | =                                                                                       |                |
|      |              | 292                 | Table 17.1 I/O Port Specifications, changed                                             |                |
|      |              | 309                 | Table 17.7 Handling of Unused Pins, changed                                             | TN-RX*-A113A/E |
|      |              |                     | nction Pin Controller (MPC)                                                             | 111107 7111077 |
|      |              | 319                 | 18.2.4 P3n Pin Function Control Registers (P3nPFS) (n = 0 to 2), changed                |                |
|      |              | 320                 | 18.2.6 P5n Pin Function Control Register (P5nPFS) (n = 4 to 5), added                   |                |
|      |              |                     | nction Timer Pulse Unit 2 (MTU2a)                                                       |                |
|      |              | All                 | Terms changed:                                                                          |                |
|      |              | All                 | counter clock → count clock, presetting → setting,                                      |                |
|      |              |                     | synchronous presetting → synchronous setting                                            |                |
|      |              | 334                 | 19. Multi-Function Timer Pulse Unit 2 (MTU2a): PCLKB description added                  |                |
|      |              | 335                 | Table 19.2 MTU Functions, changed                                                       |                |
|      |              | 349                 | Table 19.19 TIORU, TIORV, and TIORW (MTU5), changed                                     |                |
|      |              | 376                 | 19.3.3 Buffer Operation (2) Examples of Buffer Operation: (b) When TGR is               |                |
|      |              | 0/0                 | an Input Capture Register changed                                                       |                |
|      |              | 379                 | 19.3.4 Cascaded Operation: (2) Cascaded Operation Example (a) changed                   |                |
|      |              | 387                 | 19.3.6 Phase Counting Mode, changed                                                     |                |
|      |              | 393                 | 19.3.7 External Pulse Width Measurement, changed                                        |                |
|      |              | 417                 | 19.6.16 Simultaneous Input Capture in MTU1.TCNT and MTU2.TCNT in                        |                |
|      |              |                     |                                                                                         |                |
|      |              |                     | Cascade Connection, changed                                                             |                |
|      |              | 20 Compare          | Cascade Connection, changed                                                             |                |
|      |              |                     | e Match Timer (CMT)                                                                     |                |
|      |              | 436                 | Match Timer (CMT)     20. Compare Match Timer (CMT): PCLKB description added            |                |
|      |              | 436<br>21. Realtime | Match Timer (CMT)  20. Compare Match Timer (CMT): PCLKB description added  Clock (RTCA) |                |
|      |              | 436                 | Match Timer (CMT)     20. Compare Match Timer (CMT): PCLKB description added            | TN-RX*-A113A/E |



| Rev. | Date         | Page                       | Description                                                                                                                                 | Classification                   |
|------|--------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| 1.10 | Dec 10, 2014 | •                          | Summary lent Watchdog Timer (IWDTa)                                                                                                         |                                  |
| 1.10 | Dec 10, 2014 | 479                        | 22. Independent Watchdog Timer (IWDTa): PCLKB description added                                                                             |                                  |
|      |              | 493                        | 22.3.3 Refresh Operation: [Sample refreshing timings] changed                                                                               |                                  |
|      |              | 494                        | Figure 22.6 IWDT Refresh Operation Waveforms (IWDTCR.CKS[3:0] =                                                                             |                                  |
|      |              | 434                        | 0000b, IWDTCR.TOPS[1:0] = 11b), changed                                                                                                     |                                  |
|      |              | 497                        | 22.3.8 Correspondence between Option Function Select Register 0 (OFS0)                                                                      |                                  |
|      |              | 23. Serial Co              | and IWDT Registers, changed mmunications Interface (SCIe, SCIf)                                                                             |                                  |
|      |              | 498                        | 23. Serial Communications Interface (SCIe, SCIf): PCLKB description added                                                                   |                                  |
|      |              | 514 to 517                 | 23.2.7 Serial Status Register (SSR), changed                                                                                                |                                  |
|      |              | 579                        | 23.6.5 SCI Initialization (Smart Card Interface Mode): Description changed                                                                  |                                  |
|      |              | 24. I <sup>2</sup> C Bus I | nterface (RIIC)                                                                                                                             |                                  |
|      |              | 630                        | 24. I <sup>2</sup> C Bus Interface (RIIC): PCLKB description added                                                                          |                                  |
|      |              | 630, 631                   | Table 24.1 RIIC Specifications, changed                                                                                                     |                                  |
|      |              | 637                        | 24.2.2 I <sup>2</sup> C Bus Control Register 2 (ICCR2): TRS bit changed                                                                     |                                  |
|      |              | 640                        | 24.2.4 I <sup>2</sup> C Bus Mode Register 2 (ICMR2): Bit function table changed                                                             |                                  |
|      |              | 642                        | 24.2.5 I <sup>2</sup> C Bus Mode Register 3 (ICMR3): Bit function table changed                                                             |                                  |
|      |              | 648                        | 24.2.8 I <sup>2</sup> C Bus Interrupt Enable Register (ICIER): Bit function table changed                                                   |                                  |
|      |              | 660                        | Table 24.5 Examples of ICBRH/ICBRL Settings for Transfer Rate, changed                                                                      |                                  |
|      |              | 662                        | 24.2.18 Timeout Internal Counter (TMOCNT), changed                                                                                          |                                  |
|      |              | 698                        | Figure 24.39 Timeout Function (ICMR1.CKS[2:0] = 000b): Title changed                                                                        |                                  |
|      |              | 703                        | Table 24.7 Interrupt Sources, changed                                                                                                       |                                  |
|      |              |                            | ripheral Interface (RSPI)                                                                                                                   |                                  |
|      |              | All                        | Terms changed: "always", deleted                                                                                                            |                                  |
|      |              | 706                        | 25. Serial Peripheral Interface (RSPI): PCLKB description added                                                                             |                                  |
|      |              | 721                        | 25.2.8 RSPI Bit Rate Register (SPBR), changed                                                                                               |                                  |
|      |              | . = .                      | Table 25.3 Relationship among SPBR Settings, BRDV[1:0] Settings, and Bit Rates, changed                                                     |                                  |
|      |              | 27. 12-Bit A/I             | D Converter (S12ADb)                                                                                                                        |                                  |
|      |              | 790                        | 27. 12-Bit A/D Converter (S12ADb): PCLKB description added                                                                                  |                                  |
|      |              | 827                        | 27.6.10 Voltage Range of Analog Power Supply Pins, changed                                                                                  | TN-RX*-A113A/E                   |
|      |              | 828                        | 27.6.13 Port Setting When 12-Bit A/D Converter Inputs are Used, changed 27.6.14 Sequence of Powering on AVCC0 and VCC added                 |                                  |
|      |              | 28. Temperat               | ture Sensor (TEMPSA)                                                                                                                        |                                  |
|      |              | 830                        | 28.2.1 Temperature Sensor Calibration Data Register (TSCDRH, TSCDRL), added                                                                 | TN-RX*-A113A/E                   |
|      |              | 831, 832                   | 28.3.1 Before Using the Temperature Sensor, changed                                                                                         |                                  |
|      |              | 31. Flash Me               | Figure 32.2 Error in the Measured Temperature (Designed Value), added                                                                       |                                  |
|      |              |                            |                                                                                                                                             |                                  |
|      |              | All                        | Terms changed: consecutive read → unique ID read                                                                                            | TN-RX*-A112A/E                   |
|      |              | 841                        | 31. Flash Memory and Table 31.1 Flash Memory Specifications, changed                                                                        | IN-KA -AIIZA/E                   |
|      |              | 842                        | Figure 31.1 ROM Area and Block Configuration and Table 31.2 Correspondence Between ROM Capacity and Addresses for Reading, changed          |                                  |
|      |              | 843                        | 31.3.1 Flash P/E Mode Entry Register (FENTRYR): Register description and FENTRYO bit description changed                                    | TN-RX*-A112A/E                   |
|      |              | 845                        | 31.3.4 Flash P/E Mode Control Register (FPMCR): Bit function table, register description, and FMS0, FMS1, and FMS2 bits description changed |                                  |
|      |              | 848                        | 31.3.6 Flash Reset Register (FRESETR): Register description changed                                                                         |                                  |
|      |              | 848                        | 31.3.7 Flash Area Select Register (FASR): EXS bit description changed                                                                       | TN-RX*-A112A/E                   |
|      |              | 849, 850                   | 31.3.8 Flash Control Register (FCR), changed                                                                                                | TN-RX*-A113A/E<br>TN-RX*-A112A/E |
|      |              | 850, 851                   | 31.3.9 Flash Extra Area Control Register (FEXCR): Bit function table and Note 1, and CMD[2:0] bits description changed                      | TN-RX*-A112A/E                   |
|      |              | 851                        | 31.3.10 Flash Processing Start Address Register H (FSARH): Register description changed                                                     | TN-RX*-A112A/E                   |
|      |              | 852                        | 31.3.11 Flash Processing Start Address Register L (FSARL): Register description changed                                                     | TN-RX*-A112A/E                   |
|      |              | 852                        | 31.3.12 Flash Processing End Address Register H (FEARH): Register                                                                           |                                  |
|      |              | 002                        | description changed                                                                                                                         |                                  |



| Rev. | Date         |            | Description                                                                                                                                                                                                  | Classification                   |
|------|--------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
|      |              | Page       | Summary                                                                                                                                                                                                      | oo                               |
| 1.10 | Dec 10, 2014 | 853        | 31.3.13 Flash Processing End Address Register L (FEARL), changed                                                                                                                                             |                                  |
|      |              | 853        | 31.3.14 Flash Read Buffer Register H (FRBH) and 31.3.15 Flash Read Buffer Register L (FRBL), changed                                                                                                         | TN-RX*-A113A/E                   |
|      |              | 855, 856   | 31.3.18 Flash Status Register 0 (FSTATR0): Bit function table, PRGERR flag description, BCERR flag description, and ILGLERR flag description changed                                                         | TN-RX*-A112A/E                   |
|      |              | 857        | 31.3.19 Flash Status Register 1 (FSTATR1): DRRDY flag description added, FRDY flag description changed                                                                                                       | TN-RX*-A113A/E<br>TN-RX*-A112A/E |
|      |              | 858        | 31.3.20 Flash Error Address Monitor Register H (FEAMH): Register description changed 31.3.21 Flash Error Address Monitor Register L (FEAML): Register                                                        | TN-RX*-A112A/E                   |
|      |              | 859        | description changed 31.3.23 Flash Access Window Start Address Monitor Register (FAWSMR):                                                                                                                     | TN-RX*-A112A/E                   |
|      |              | 860        | Note 1 changed  31.3.24 Flash Access Window End Address Monitor Register (FAWEMR):                                                                                                                           | TN-RX*-A112A/E                   |
|      |              |            | Note 1 changed                                                                                                                                                                                               |                                  |
|      |              | 860        | 31.4.25 Unique ID Register n (UIDRn) (n = 0 to 31), added                                                                                                                                                    | TN-RX*-A113A/E                   |
|      |              | 861        | Figure 31.2 Overview of the Start-Up Program Protection, changed                                                                                                                                             | TN-RX*-A112A/E                   |
|      |              | 862        | 31.5 Area Protection: Description and Figure 31.3 Area Protection Overview (When Blocks 4 to 6 are Set as the Access Window While the ROM Capacity is 128 Bytes) changed                                     | TN-RX*-A112A/E                   |
|      |              | 863 to 872 | The structure of sections in 31.6 Programming and Erasure, changed                                                                                                                                           | TN-RX*-A112A/E                   |
|      |              | 863        | 31.6.1 Sequencer Modes, Figure 31.4 Mode Transitions of the Flash Memory, and 31.6.1.1 Read Mode, changed                                                                                                    | TN-RX*-A112A/E                   |
|      |              | 863        | 31.6.1.2 P/E Modes, changed                                                                                                                                                                                  |                                  |
|      |              | 864        | Figure 31.5 Procedure for Transition from ROM Read Mode to ROM P/E Mode changed                                                                                                                              | TN-RX*-A112A/E                   |
|      |              | 865        | Figure 31.6 Procedure for Transition from ROM P/E Mode to ROM Read Mode changed                                                                                                                              | TN-RX*-A112A/E                   |
|      |              | 866        | Table 31.4 Software Commands, changed                                                                                                                                                                        | TN-RX*-A113A/E                   |
|      |              | 867        | 31.6.4 Software Command Usage and Figure 31.7 Procedure to Issue the Program Command for the ROM, changed                                                                                                    | TN-RX*-A112A/E                   |
|      |              | 868        | Figure 31.8 Procedure to Issue the Block Erase Command, changed                                                                                                                                              | TN-RX*-A112A/E                   |
|      |              | 869        | Figure 31.9 Procedure to Issue the Blank Check Command, changed                                                                                                                                              | TN-RX*-A112A/E                   |
|      |              | 870        | 31.6.4.4 Start-Up Area Information Program/Access Window Information Program description and Figure 31.10 Procedure to Issue the Start-Up Area Information Program Command/Access Window Information Program | TN-RX*-A112A/E                   |
|      |              | 871        | Command, changed  31.6.4.5 Unique ID Read and Figure 31.11 Procedure to Issue the Unique ID Read Command, added                                                                                              | TN-RX*-A113A/E                   |
|      |              | 872        | 31.6.4.6 Forced Stop of Software Commands and Figure 31.12 Procedure for Forced Stop of Software Commands, added                                                                                             | TN-RX*-A112A/E                   |
|      |              | 873        | Table 31.5 I/O Pins Used in Boot Mode, changed                                                                                                                                                               | TN-RX*-A112A/E                   |
|      |              | 877        | Table 31.8 Boot Mode ID Code Protection Specifications, changed                                                                                                                                              |                                  |
|      |              | 878        | Figure 31.17 Authentication for Boot Mode ID Code Protection and (2) ID Code 1 to ID Code 15, changed                                                                                                        |                                  |
|      |              | 879        | Table 31.9 On-Chip Debugging Emulator ID Code Protection Specifications, changed                                                                                                                             |                                  |
|      |              | 882        | 31.9.3 Boot Mode Status Inquiry, changed                                                                                                                                                                     | TN-RX*-A112A/E                   |
|      |              | 883        | Table 31.12 Inquiry Commands, changed                                                                                                                                                                        | TN-RX*-A112A/E                   |
|      |              | 884        | 31.9.4.4 Block Information Inquiry, changed                                                                                                                                                                  | ,                                |
|      |              | 886        | 31.9.5.2 Operating Frequency Select: Section number changed                                                                                                                                                  | TN-RX*-A112A/E                   |
|      |              | 887        | 31.9.5.3 Program/Erase State Transition: Section number changed                                                                                                                                              | TN-RX*-A112A/E                   |
|      |              |            | -                                                                                                                                                                                                            | TN-RX*-A112A/E                   |
|      |              | 888        | 31.9.6 ID Code Authentication Command and 31.9.6.1 ID Code Check: Section number changed                                                                                                                     | IN-IXX -AIIZA/L                  |
|      |              | 888        | Section number changed 31.9.6.2 Erase Ready and Table 31.17 Acceptable Commands for Each                                                                                                                     |                                  |
|      |              | 889        | Section number changed 31.9.6.2 Erase Ready and Table 31.17 Acceptable Commands for Each State, changed                                                                                                      |                                  |
|      |              | 889<br>891 | Section number changed 31.9.6.2 Erase Ready and Table 31.17 Acceptable Commands for Each State, changed 31.9.7.3 Erase Preparation, changed                                                                  |                                  |
|      |              | 889        | Section number changed 31.9.6.2 Erase Ready and Table 31.17 Acceptable Commands for Each State, changed                                                                                                      | TN-RX*-A112A/E                   |



| Rev. | Date           |                    | Description                                                                                                                                                                        | Classification |
|------|----------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
|      |                | Page               | Summary                                                                                                                                                                            |                |
| 1.10 | Dec 10, 2014   | 897                | Figure 31.19 Transmit/Receive Data for Bit Rate Automatic Adjustment, changed                                                                                                      | TN-RX*-A112A/E |
|      |                | 898                | 31.9.9.2 Procedure to Receive the MCU Information and Figure 31.21 Procedure to Send Inquiry Commands, changed                                                                     | TN-RX*-A112A/E |
|      |                | 899                | 31.9.9.3 Procedure to Select the Device and Change the Bit Rate and Figure                                                                                                         | TN-RX*-A112A/E |
|      |                |                    | 31.22 Procedure to Select the Device and Change the Bit Rate, changed                                                                                                              |                |
|      |                | 901                | 31.9.9.5 Disable Boot Mode ID Code Protection, changed                                                                                                                             |                |
|      |                | 902                | 31.9.9.6 Erase Ready Operation and Figure 31.25 Procedure to Send Commands in Erase Ready Operation, changed                                                                       | TN-RX*-A112A/E |
|      |                | 906                | 31.9.9.10 Set the Access Window in the User Area, changed                                                                                                                          | TN-RX*-A112A/E |
|      |                | 907                | 31.10.1 Overview description and Figure 31.30 Self-Programming Overview, changed                                                                                                   | TN-RX*-A112A/E |
|      |                | 908                | 31.11 Usage Notes: (1) Access the Block Where Erase Operation is Forcibly Stopped, (2) Processing After Forced Stop of Erase Operation, and (10) FCLK during Program/Erase changed | TN-RX*-A112A/E |
|      |                | 32 Flectrical      | Characteristics                                                                                                                                                                    |                |
|      |                | 910                | Table 32.1 Absolute Maximum Ratings, changed                                                                                                                                       |                |
|      |                | 910                | Table 32.2 Operating Conditions, changed                                                                                                                                           | TN-RX*-A113A/E |
|      |                | 911                | Table 32.3 DC Characteristics (1) and Table 32.4 DC Characteristics (2), changed                                                                                                   | TN-RX*-A113A/E |
|      |                | 916                | Table 32.8 DC Characteristics (6), changed                                                                                                                                         |                |
|      |                | 918                | Table 32.11 DC Characteristics (9), changed                                                                                                                                        |                |
|      |                | 920                | Table 32.17 Output Voltage (1) and Table 32.18 Output Voltage (2), changed                                                                                                         | TN-RX*-A113A/E |
|      |                | 928                | Table 32.22 Clock Timing, changed                                                                                                                                                  | TH TOX -ATTOME |
|      |                | 939                | Table 32.33 Timing of On-Chip Peripheral Modules (4): Note 2 deleted                                                                                                               |                |
|      |                | 940                | Table 32.34 Timing of On-Chip Peripheral Modules (5): Note 1 deleted                                                                                                               |                |
|      |                | 947                | Figure 32.47 AVCC0 to AVREFH0 Voltage Range, changed                                                                                                                               |                |
|      |                | 956                | 32.8 ROM (Flash Memory for Code Storage) Characteristics, changed                                                                                                                  |                |
| 1.20 | Jul 29, 2016   | 1. Overview        | ozio Nom (Hadri Montor) for obad diorago) orial addonosios, orial god                                                                                                              |                |
| 0    | oa. 20, 20 · 0 | 49 to 56           | Table 1.5 to 1.9 Note 1 regarding I/O power source is AVCC0 for the ports (P4, PJ6, and PJ7), added                                                                                |                |
|      |                | 7. Option-Se       |                                                                                                                                                                                    |                |
|      |                | 120                | 7.2.2 Option Function Select Register 1 (OFS1): Note 2 added                                                                                                                       | TN-RX*-A153A/E |
|      |                | 123                | 7.3.2 Note on Parallel Use of the Voltage Monitoring 1 Reset and IWDT Reset, added                                                                                                 | TN-RX*-A153A/E |
|      |                | 14. Interrupt      | Controller (ICUb)                                                                                                                                                                  |                |
|      |                | 235                | Table 14.3 Interrupt Vector Table (2/7) FCU, added                                                                                                                                 | TN-RX*-A132A/E |
|      |                |                    | nsfer Controller (DTCa)                                                                                                                                                            |                |
|      |                | 290                | 16.8 Low Power Consumption Function: (2) Deep Sleep Mode and (4) Notes on Low Power Consumption Function, added                                                                    |                |
|      |                | 17. I/O Ports      | ( · / · · · · · · · · · · · · · · · · ·                                                                                                                                            |                |
|      |                | 293                | Table 17.2 A column of the I/O level for the I/O port function, added                                                                                                              |                |
|      |                | 297                | Figure 17.4 I/O Port Configuration (4) Erroneous description in the polarity of the oscillator control, corrected                                                                  |                |
|      |                |                    | $0: ON \rightarrow OFF, 1: OFF \rightarrow ON$                                                                                                                                     |                |
|      |                | 305                | Figure 17.6 Example of Switching General-Purpose I/O Port by the PSRA Register, added                                                                                              |                |
|      |                | 306                | Figure 17.7 Example of Switching General-Purpose I/O Port by the PSRB Register, added                                                                                              |                |
|      |                | 309                | Table 17.7 Handling of Unused Pins, changed                                                                                                                                        |                |
|      |                | 18. Multi-Fun      | ction Pin Controller (MPC)                                                                                                                                                         |                |
|      |                | —<br>19. Multi-Fur | 18.2.6 P5n Pin Function Select Registers (P5nPFS) (n = 4, 5), deleted ction Timer Pulse Unit 2 (MTU2a)                                                                             |                |
|      |                | 344                | Table 19.11 TIORH (MTU0): Note 1 added                                                                                                                                             |                |
|      |                | 345                | Table 19.12 TIORL (MTU0): Note 2 added                                                                                                                                             |                |
|      |                | 346                | Table 19.15 TIORH (MTU0): Note 1 added                                                                                                                                             |                |
|      |                | 347                | Table 19.16 TIORL (MTU0): Note 2 added                                                                                                                                             |                |
|      |                |                    | ent Watchdog Timer (IWDTa)                                                                                                                                                         |                |
|      |                | 484                | 22.4.3 Note on Parallel Use of the Voltage Monitoring 1 Reset and IWDT                                                                                                             |                |
|      |                |                    | Reset, added                                                                                                                                                                       |                |



| Rev. | Date       | Drivi                      | Description                                                                                                                                                             | Classification |
|------|------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 4.00 | 0040.07.00 | Page                       | Summary                                                                                                                                                                 |                |
| 1.20 | 2016.07.29 |                            | mmunications Interface (SCIe, SCIf)                                                                                                                                     |                |
|      |            | 488                        | Figure 23.1 Block Diagram of SCIe (SCI1), deleted title changed Figure 23.2 Block Diagram of SCIe (SCI5) → Figure 23.1 Block Diagram of SCIe (SCI1 and SCI5)            |                |
|      |            | 492                        | 23.2.5 Serial Mode Register (SMR)                                                                                                                                       |                |
|      |            |                            | (1) Non-Smart Card Interface Mode (SCMR.SMIF = 0)<br>b7 changed                                                                                                         |                |
|      |            | 500                        | 23.2.7 Serial Status Register (SSR) (1) Non-Smart Card Interface Mode (SCMR.SMIF = 0) b6 and b7 changed                                                                 | TN-RX*-A138A/E |
|      |            | 500                        | 23.2.7 Serial Status Register (SSR) (1) Non-Smart Card Interface Mode (SCMR.SMIF = 0) Note 1, changed and Note 2, added                                                 | TN-RX*-A138A/E |
|      |            | 500 to 502                 | 23.2.7 Serial Status Register (SSR) (1) Non-Smart Card Interface Mode (SCMR.SMIF = 0) RDRF and TDRE, description added                                                  | TN-RX*-A138A/E |
|      |            | 503                        | 23.2.7 Serial Status Register (SSR) (2) Smart Card Interface Mode (SCMR.SMIF = 1) b6 and b7 changed                                                                     | TN-RX*-A138A/E |
|      |            | 503                        | 23.2.7 Serial Status Register (SSR) (2) Smart Card Interface Mode (SCMR.SMIF = 1) Note 1, changed and Note 2, added                                                     | TN-RX*-A138A/E |
|      |            | 504                        | 23.2.7 Serial Status Register (SSR) (2) Smart Card Interface Mode (SCMR.SMIF = 1) RDRF and TDRE, description added                                                      | TN-RX*-A138A/E |
|      |            | 606                        | Table 23.32 SCI Interrupt Sources, changed                                                                                                                              | TN-RX*-A138A/E |
|      |            | 616                        | 23.12.15 Note on Stopping Reception When the RTS Function is in Use, added                                                                                              | TN-RX*-A151A/  |
|      |            | 24. I <sup>2</sup> C Bus I | nterface (RIIC)                                                                                                                                                         |                |
|      |            | 638                        | 24.2.9 I <sup>2</sup> C-bus Status Register 1 (ICSR1)<br>HOA Flag, description changed                                                                                  | TN-RX*-A141A/  |
|      |            | 25. Serial Pe              | ripheral Interface (RSPI)                                                                                                                                               |                |
|      |            | 702                        | 25.2.4 RSPI Status Register (SPSR), SPTEF Flag, SPRF Flag and Note2 added                                                                                               | TN-RX*-A138A/  |
|      |            | 703                        | 25.2.4 RSPI Status Register (SPSR), SPTEF Flag and SPRF Flag description added                                                                                          | TN-RX*-A138A/  |
|      |            | _                          | Change by SPTEF Flag and SPRF Flag addition                                                                                                                             | TN-RX*-A138A/  |
|      |            | 754                        | (a) Transmit Processing Flow, changed                                                                                                                                   | TN-RX*-A147A/I |
|      |            | 31. Flash Me               |                                                                                                                                                                         |                |
|      |            | 829                        | Table 31.1 Flash Memory Specifications, Interrupt added                                                                                                                 | TN-RX*-A132A/I |
|      |            | 830                        | 31.2 ROM Area and Block Configuration, changed                                                                                                                          | TN-RX*-A132A/  |
|      |            | 838<br>846                 | 31.3.8 Flash Control Register (FCR), [Block erase] changed 31.3.19 Flash Status Register 1 (FSTATR1): FRDY Flag and EXRDY Flag, changed                                 | TN-RX*-A132A/I |
|      |            | 861                        | 31.6.5 Interrupt, added                                                                                                                                                 | TN-RX*-A132A/I |
|      |            | 866                        | 31.7.2 Boot Mode (FINE Interface), added                                                                                                                                | TN-RX*-A132A/  |
|      |            |                            | Characteristics                                                                                                                                                         |                |
|      |            | 901                        | Table 32.1 Absolute Maximum Ratings, Analog power supply voltage added                                                                                                  |                |
|      |            | 901                        | Table 32.2 Recommended Operating Conditions, VREFH0 / VREFL0 added                                                                                                      |                |
|      |            | 907                        | Table 32.8 DC Characteristics (6), Increment for IWDT operation added                                                                                                   |                |
|      |            | 908                        | Table 32.9 DC Characteristics (7) Permissible total consumption power added                                                                                             | TN-RX*-A135A/I |
|      |            | 909                        | Table 32.10 DC Characteristics (8), LDV1,2 added                                                                                                                        |                |
|      |            | 910, 911                   | Table 32.15 Permissible Output Currents is divided into D version and G version                                                                                         |                |
|      |            | 949                        | Table 32.45 ROM (Flash Memory for Code Storage) Characteristics (2), Erasure time - 128-Kbyte added                                                                     | TN-RX*-A132A/I |
|      |            | 950                        | Table 32.46 ROM (Flash Memory for Code Storage) Characteristics (3), Temperature range for the programming/erasure operation changed and Erasure time - 128-Kbyte added | TN-RX*-A132A/E |
|      |            | 951, 952                   | 32.9 Usage Notes added                                                                                                                                                  |                |



RX110 Group User's Manual: Hardware

Dec 20, 2013 Jul 29, 2016 Publication Date: Rev.1.00

Rev.1.20

Published by: Renesas Electronics Corporation



#### **SALES OFFICES**

# Renesas Electronics Corporation

http://www.renesas.com

Refer to "http://www.renesas.com/" for the latest and detailed information.

Renesas Electronics America Inc. 2801 Scott Boulevard Santa Clara, CA 95050-2549, U.S.A. Tel: +1-408-588-6000, Fax: +1-408-588-6130

Renesas Electronics Canada Limited 9251 Yonge Street, Suite 8309 Richmond Hill, Ontario Canada L4C 9T3 Tel: +1-905-237-2004

Renesas Electronics Europe Limited
Dukes Meadow, Millboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K
Tel: +44-1628-585-100, Fax: +44-1628-585-900

Renesas Electronics Europe GmbH

Arcadiastrasse 10, 40472 Düsseldorf, Germany Tel: +49-211-6503-0, Fax: +49-211-6503-1327

Renesas Electronics (China) Co., Ltd. Room 1709, Quantum Plaza, No.27 ZhiChunLu Haidian District, Beijing 100191, P.R.China Tel: +86-10-8235-1155, Fax: +86-10-8235-7679

Renesas Electronics (Shanghai) Co., Ltd.
Unit 301, Tower A, Central Towers, 555 Langao Road, Putuo District, Shanghai, P. R. China 200333 Tel: +86-21-2226-0888, Fax: +86-21-2226-0999

Renesas Electronics Hong Kong Limited
Unit 1601-1611, 16/F., Tower 2, Grand Century Place, 193 Prince Edward Road West, Mongkok, Kowloon, Hong Kong Tel: +852-2265-6688, Fax: +852 2886-9022

Renesas Electronics Taiwan Co., Ltd. 13F, No. 363, Fu Shing North Road, Taipei 10543, Taiwan Tel: +886-2-8175-9600, Fax: +886 2-8175-9670

Renesas Electronics Singapore Pte. Ltd. 80 Bendemeer Road, Unit #06-02 Hyflux Innovation Centre, Singapore 339949 Tel: +65-6213-0200, Fax: +65-6213-0300

Renesas Electronics Malaysia Sdn.Bhd.
Unit 1207, Block B, Menara Amcorp, Amcorp Trade Centre, No. 18, Jln Persiaran Barat, 46050 Petaling Jaya, Selangor Darul Ehsan, Malaysia Tel: +60-3-7955-9390, Fax: +60-3-7955-9510

Renesas Electronics India Pvt. Ltd.
No.777C, 100 Feet Road, HAL II Stage, Indiranagar, Bangalore, India Tel: +91-80-67208700, Fax: +91-80-67208777

Renesas Electronics Korea Co., Ltd. 12F., 234 Teheran-ro, Gangnam-Gu, Seoul, 135-080, Korea Tel: +82-2-558-3737, Fax: +82-2-558-5141

© 2016 Renesas Electronics Corporation. All rights reserved.

RX110 Group

